tag | line | file | source code |
inode | 185 | arch/alpha/kernel/osf_sys.c | struct inode * inode; |
inode | 193 | arch/alpha/kernel/osf_sys.c | retval = namei(path, &inode); |
inode | 196 | arch/alpha/kernel/osf_sys.c | if (!inode->i_sb->s_op->statfs) { |
inode | 197 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 200 | arch/alpha/kernel/osf_sys.c | inode->i_sb->s_op->statfs(inode->i_sb, buffer, bufsiz); |
inode | 201 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 208 | arch/alpha/kernel/osf_sys.c | struct inode * inode; |
inode | 218 | arch/alpha/kernel/osf_sys.c | if (!(inode = file->f_inode)) |
inode | 220 | arch/alpha/kernel/osf_sys.c | if (!inode->i_sb->s_op->statfs) |
inode | 222 | arch/alpha/kernel/osf_sys.c | inode->i_sb->s_op->statfs(inode->i_sb, buffer, bufsiz); |
inode | 253 | arch/alpha/kernel/osf_sys.c | static int getdev(const char * name, int rdonly, struct inode ** ino) |
inode | 256 | arch/alpha/kernel/osf_sys.c | struct inode * inode; |
inode | 260 | arch/alpha/kernel/osf_sys.c | retval = namei(name, &inode); |
inode | 263 | arch/alpha/kernel/osf_sys.c | if (!S_ISBLK(inode->i_mode)) { |
inode | 264 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 267 | arch/alpha/kernel/osf_sys.c | if (IS_NODEV(inode)) { |
inode | 268 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 271 | arch/alpha/kernel/osf_sys.c | dev = inode->i_rdev; |
inode | 273 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 278 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 284 | arch/alpha/kernel/osf_sys.c | dummy.f_inode = inode; |
inode | 286 | arch/alpha/kernel/osf_sys.c | retval = fops->open(inode, &dummy); |
inode | 288 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 292 | arch/alpha/kernel/osf_sys.c | *ino = inode; |
inode | 296 | arch/alpha/kernel/osf_sys.c | static void putdev(struct inode * inode) |
inode | 300 | arch/alpha/kernel/osf_sys.c | fops = get_blkfops(MAJOR(inode->i_rdev)); |
inode | 302 | arch/alpha/kernel/osf_sys.c | fops->release(inode, NULL); |
inode | 313 | arch/alpha/kernel/osf_sys.c | struct inode * inode; |
inode | 320 | arch/alpha/kernel/osf_sys.c | retval = getdev(tmp.devname, 0, &inode); |
inode | 323 | arch/alpha/kernel/osf_sys.c | retval = do_mount(inode->i_rdev, tmp.devname, dirname, "ext2", flags, NULL); |
inode | 325 | arch/alpha/kernel/osf_sys.c | putdev(inode); |
inode | 326 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 333 | arch/alpha/kernel/osf_sys.c | struct inode * inode; |
inode | 340 | arch/alpha/kernel/osf_sys.c | retval = getdev(tmp.devname, 1, &inode); |
inode | 343 | arch/alpha/kernel/osf_sys.c | retval = do_mount(inode->i_rdev, tmp.devname, dirname, "iso9660", flags, NULL); |
inode | 345 | arch/alpha/kernel/osf_sys.c | putdev(inode); |
inode | 346 | arch/alpha/kernel/osf_sys.c | iput(inode); |
inode | 1020 | arch/m68k/amiga/amifb.c | static int amiga_fb_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 2688 | arch/m68k/amiga/amifb.c | static int mono_amiga_fb_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 4586 | arch/m68k/amiga/amifb.c | static int amiga_fb_ioctl(struct inode *inode, struct file *file, |
inode | 2688 | arch/m68k/atari/atafb.c | atari_fb_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 57 | arch/m68k/atari/joystick.c | static void release_joystick(struct inode *inode, struct file *file) |
inode | 59 | arch/m68k/atari/joystick.c | int minor = DEVICE_NR(inode->i_rdev); |
inode | 68 | arch/m68k/atari/joystick.c | static int open_joystick(struct inode *inode, struct file *file) |
inode | 70 | arch/m68k/atari/joystick.c | int minor = DEVICE_NR(inode->i_rdev); |
inode | 72 | arch/m68k/atari/joystick.c | if (!DIGITAL_JOY(inode->i_rdev) || minor > 1) |
inode | 82 | arch/m68k/atari/joystick.c | static int write_joystick(struct inode *inode, struct file *file, |
inode | 88 | arch/m68k/atari/joystick.c | static int read_joystick(struct inode *inode, struct file *file, |
inode | 91 | arch/m68k/atari/joystick.c | int minor = DEVICE_NR(inode->i_rdev); |
inode | 107 | arch/m68k/atari/joystick.c | static int joystick_select(struct inode *inode, struct file *file, int sel_type, select_table *wait) |
inode | 109 | arch/m68k/atari/joystick.c | int minor = DEVICE_NR(inode->i_rdev); |
inode | 50 | arch/sparc/kernel/sys_sparc.c | struct inode *inode = file->f_inode; |
inode | 63 | arch/sparc/kernel/sys_sparc.c | if (!suser() && (inode->i_mode & (S_ISUID | S_ISGID))) { |
inode | 65 | arch/sparc/kernel/sys_sparc.c | newattrs.ia_mode = inode->i_mode & ~(S_ISUID | S_ISGID); |
inode | 67 | arch/sparc/kernel/sys_sparc.c | notify_change(inode, &newattrs); |
inode | 70 | arch/sparc/kernel/sys_sparc.c | down(&inode->i_sem); |
inode | 71 | arch/sparc/kernel/sys_sparc.c | error = file->f_op->write(inode,file,buf,count); |
inode | 72 | arch/sparc/kernel/sys_sparc.c | up(&inode->i_sem); |
inode | 649 | arch/sparc/kernel/sys_sunos.c | struct inode *inode; |
inode | 653 | arch/sparc/kernel/sys_sunos.c | inode = file->f_inode; |
inode | 654 | arch/sparc/kernel/sys_sunos.c | if (!inode || !inode->i_sock) |
inode | 657 | arch/sparc/kernel/sys_sunos.c | socket = &inode->u.socket_i; |
inode | 898 | arch/sparc/kernel/sys_sunos.c | struct inode * inode; |
inode | 900 | arch/sparc/kernel/sys_sunos.c | int (*select) (struct inode *, struct file *, int, select_table *); |
inode | 902 | arch/sparc/kernel/sys_sunos.c | inode = file->f_inode; |
inode | 904 | arch/sparc/kernel/sys_sunos.c | return select(inode, file, flag, wait) |
inode | 905 | arch/sparc/kernel/sys_sunos.c | || (wait && select(inode, file, flag, NULL)); |
inode | 906 | arch/sparc/kernel/sys_sunos.c | if (S_ISREG(inode->i_mode)) |
inode | 1401 | drivers/block/amiflop.c | static int fd_ioctl(struct inode *inode, struct file *filp, |
inode | 1404 | drivers/block/amiflop.c | int drive = inode->i_rdev & 3; |
inode | 1413 | drivers/block/amiflop.c | fsync_dev(inode->i_rdev); |
inode | 1437 | drivers/block/amiflop.c | invalidate_inodes(inode->i_rdev); |
inode | 1438 | drivers/block/amiflop.c | invalidate_buffers(inode->i_rdev); |
inode | 1598 | drivers/block/amiflop.c | static int floppy_open(struct inode *inode, struct file *filp) |
inode | 1604 | drivers/block/amiflop.c | drive = inode->i_rdev & 3; |
inode | 1608 | drivers/block/amiflop.c | if (old_dev != inode->i_rdev) |
inode | 1615 | drivers/block/amiflop.c | fd_device[drive] = inode->i_rdev; |
inode | 1617 | drivers/block/amiflop.c | if (old_dev && old_dev != inode->i_rdev) |
inode | 1621 | drivers/block/amiflop.c | check_disk_change(inode->i_rdev); |
inode | 1634 | drivers/block/amiflop.c | system=(inode->i_rdev & 4)>>2; |
inode | 1646 | drivers/block/amiflop.c | static void floppy_release(struct inode * inode, struct file * filp) |
inode | 1650 | drivers/block/amiflop.c | fsync_dev(inode->i_rdev); |
inode | 1651 | drivers/block/amiflop.c | invalidate_inodes(inode->i_rdev); |
inode | 1652 | drivers/block/amiflop.c | invalidate_buffers(inode->i_rdev); |
inode | 1655 | drivers/block/amiflop.c | if ((inode->i_rdev & 3) == selected && writepending) { |
inode | 1662 | drivers/block/amiflop.c | if (!fd_ref[inode->i_rdev & 3]--) { |
inode | 1664 | drivers/block/amiflop.c | fd_ref[inode->i_rdev & 3] = 0; |
inode | 383 | drivers/block/ataflop.c | static int fd_ioctl( struct inode *inode, struct file *filp, unsigned int |
inode | 388 | drivers/block/ataflop.c | static int floppy_open( struct inode *inode, struct file *filp ); |
inode | 389 | drivers/block/ataflop.c | static void floppy_release( struct inode * inode, struct file * filp ); |
inode | 1529 | drivers/block/ataflop.c | static int fd_ioctl(struct inode *inode, struct file *filp, |
inode | 1543 | drivers/block/ataflop.c | device = inode->i_rdev; |
inode | 1750 | drivers/block/ataflop.c | static int floppy_open( struct inode *inode, struct file *filp ) |
inode | 1761 | drivers/block/ataflop.c | drive = MINOR (inode->i_rdev) & 3; |
inode | 1762 | drivers/block/ataflop.c | type = MINOR(inode->i_rdev) >> 2; |
inode | 1770 | drivers/block/ataflop.c | if (old_dev != inode->i_rdev) |
inode | 1781 | drivers/block/ataflop.c | fd_device[drive] = inode->i_rdev; |
inode | 1783 | drivers/block/ataflop.c | if (old_dev && old_dev != inode->i_rdev) |
inode | 1787 | drivers/block/ataflop.c | if (filp->f_mode & 2 || permission (inode, 2) == 0) |
inode | 1796 | drivers/block/ataflop.c | check_disk_change( inode->i_rdev ); |
inode | 1799 | drivers/block/ataflop.c | floppy_release(inode, filp); |
inode | 1809 | drivers/block/ataflop.c | static void floppy_release( struct inode * inode, struct file * filp ) |
inode | 1813 | drivers/block/ataflop.c | drive = inode->i_rdev & 3; |
inode | 1818 | drivers/block/ataflop.c | block_fsync (inode, filp); |
inode | 3264 | drivers/block/floppy.c | static int fd_ioctl(struct inode *inode, struct file *filp, unsigned int cmd, |
inode | 3285 | drivers/block/floppy.c | device = inode->i_rdev; |
inode | 3490 | drivers/block/floppy.c | static int floppy_read(struct inode * inode, struct file * filp, |
inode | 3493 | drivers/block/floppy.c | int drive = DRIVE(inode->i_rdev); |
inode | 3495 | drivers/block/floppy.c | check_disk_change(inode->i_rdev); |
inode | 3498 | drivers/block/floppy.c | return block_read(inode, filp, buf, count); |
inode | 3501 | drivers/block/floppy.c | static int floppy_write(struct inode * inode, struct file * filp, |
inode | 3506 | drivers/block/floppy.c | int drive = DRIVE(inode->i_rdev); |
inode | 3510 | drivers/block/floppy.c | check_disk_change(inode->i_rdev); |
inode | 3517 | drivers/block/floppy.c | ret= block_write(inode, filp, buf, count); |
inode | 3521 | drivers/block/floppy.c | static void floppy_release(struct inode * inode, struct file * filp) |
inode | 3525 | drivers/block/floppy.c | drive = DRIVE(inode->i_rdev); |
inode | 3530 | drivers/block/floppy.c | block_fsync(inode,filp); |
inode | 3546 | drivers/block/floppy.c | #define RETERR(x) do{floppy_release(inode,filp); return -(x);}while(0) |
inode | 3548 | drivers/block/floppy.c | static int floppy_open(struct inode * inode, struct file * filp) |
inode | 3560 | drivers/block/floppy.c | drive = DRIVE(inode->i_rdev); |
inode | 3566 | drivers/block/floppy.c | if (TYPE(inode->i_rdev) >= NUMBER(floppy_type)) |
inode | 3569 | drivers/block/floppy.c | if (UDRS->fd_ref && old_dev != MINOR(inode->i_rdev)) |
inode | 3616 | drivers/block/floppy.c | UDRS->fd_device = MINOR(inode->i_rdev); |
inode | 3617 | drivers/block/floppy.c | if (old_dev != -1 && old_dev != MINOR(inode->i_rdev)) { |
inode | 3624 | drivers/block/floppy.c | if ((filp->f_mode & 2) || (permission(inode,2) == 0)) |
inode | 3636 | drivers/block/floppy.c | check_disk_change(inode->i_rdev); |
inode | 778 | drivers/block/hd.c | static int hd_ioctl(struct inode * inode, struct file * file, |
inode | 785 | drivers/block/hd.c | if ((!inode) || !(inode->i_rdev)) |
inode | 787 | drivers/block/hd.c | dev = DEVICE_NR(inode->i_rdev); |
inode | 802 | drivers/block/hd.c | put_user(hd[MINOR(inode->i_rdev)].start_sect, |
inode | 808 | drivers/block/hd.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 815 | drivers/block/hd.c | put_user(read_ahead[MAJOR(inode->i_rdev)],(long *) arg); |
inode | 822 | drivers/block/hd.c | put_user(hd[MINOR(inode->i_rdev)].nr_sects, (long *) arg); |
inode | 826 | drivers/block/hd.c | fsync_dev(inode->i_rdev); |
inode | 827 | drivers/block/hd.c | invalidate_buffers(inode->i_rdev); |
inode | 831 | drivers/block/hd.c | return revalidate_hddisk(inode->i_rdev, 1); |
inode | 835 | drivers/block/hd.c | if ((arg > 1) || (MINOR(inode->i_rdev) & 0x3F)) |
inode | 858 | drivers/block/hd.c | if (MINOR(inode->i_rdev) & 0x3F) return -EINVAL; |
inode | 876 | drivers/block/hd.c | if (MINOR(inode->i_rdev) & 0x3F) return -EINVAL; |
inode | 884 | drivers/block/hd.c | RO_IOCTLS(inode->i_rdev,arg); |
inode | 890 | drivers/block/hd.c | static int hd_open(struct inode * inode, struct file * filp) |
inode | 893 | drivers/block/hd.c | target = DEVICE_NR(inode->i_rdev); |
inode | 907 | drivers/block/hd.c | static void hd_release(struct inode * inode, struct file * file) |
inode | 910 | drivers/block/hd.c | sync_dev(inode->i_rdev); |
inode | 912 | drivers/block/hd.c | target = DEVICE_NR(inode->i_rdev); |
inode | 1958 | drivers/block/ide-cd.c | int ide_cdrom_ioctl (ide_drive_t *drive, struct inode *inode, |
inode | 2460 | drivers/block/ide-cd.c | int ide_cdrom_open (struct inode *ip, struct file *fp, ide_drive_t *drive) |
inode | 2504 | drivers/block/ide-cd.c | void ide_cdrom_release (struct inode *inode, struct file *file, |
inode | 2508 | drivers/block/ide-cd.c | invalidate_buffers (inode->i_rdev); |
inode | 881 | drivers/block/ide-tape.c | int idetape_chrdev_read (struct inode *inode, struct file *file, char *buf, int count); |
inode | 882 | drivers/block/ide-tape.c | int idetape_chrdev_write (struct inode *inode, struct file *file, const char *buf, int count); |
inode | 883 | drivers/block/ide-tape.c | int idetape_chrdev_ioctl (struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg); |
inode | 884 | drivers/block/ide-tape.c | int idetape_chrdev_open (struct inode *inode, struct file *file); |
inode | 885 | drivers/block/ide-tape.c | void idetape_chrdev_release (struct inode *inode,struct file *file); |
inode | 2804 | drivers/block/ide-tape.c | int idetape_blkdev_ioctl (ide_drive_t *drive, struct inode *inode, struct file *file, |
inode | 3585 | drivers/block/ide-tape.c | int idetape_blkdev_open (struct inode *inode, struct file *filp, ide_drive_t *drive) |
inode | 3608 | drivers/block/ide-tape.c | void idetape_blkdev_release (struct inode *inode, struct file *filp, ide_drive_t *drive) |
inode | 3649 | drivers/block/ide-tape.c | int idetape_chrdev_read (struct inode *inode, struct file *file, char *buf, int count) |
inode | 3717 | drivers/block/ide-tape.c | int idetape_chrdev_write (struct inode *inode, struct file *file, const char *buf, int count) |
inode | 3817 | drivers/block/ide-tape.c | int idetape_chrdev_ioctl (struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg) |
inode | 3866 | drivers/block/ide-tape.c | return (idetape_blkdev_ioctl (drive,inode,file,cmd,arg)); |
inode | 4090 | drivers/block/ide-tape.c | int idetape_chrdev_open (struct inode *inode, struct file *filp) |
inode | 4096 | drivers/block/ide-tape.c | unsigned int minor=MINOR (inode->i_rdev),allocation_length; |
inode | 4152 | drivers/block/ide-tape.c | void idetape_chrdev_release (struct inode *inode, struct file *filp) |
inode | 4157 | drivers/block/ide-tape.c | unsigned int minor=MINOR (inode->i_rdev); |
inode | 1774 | drivers/block/ide.c | static int ide_open(struct inode * inode, struct file * filp) |
inode | 1779 | drivers/block/ide.c | if ((drive = get_info_ptr(inode->i_rdev)) == NULL) |
inode | 1789 | drivers/block/ide.c | return ide_cdrom_open (inode, filp, drive); |
inode | 1793 | drivers/block/ide.c | return idetape_blkdev_open (inode, filp, drive); |
inode | 1798 | drivers/block/ide.c | check_disk_change(inode->i_rdev); |
inode | 1815 | drivers/block/ide.c | static void ide_release(struct inode * inode, struct file * file) |
inode | 1819 | drivers/block/ide.c | if ((drive = get_info_ptr(inode->i_rdev)) != NULL) { |
inode | 1820 | drivers/block/ide.c | fsync_dev(inode->i_rdev); |
inode | 1824 | drivers/block/ide.c | ide_cdrom_release (inode, file, drive); |
inode | 1830 | drivers/block/ide.c | idetape_blkdev_release (inode, file, drive); |
inode | 1837 | drivers/block/ide.c | invalidate_buffers(inode->i_rdev); |
inode | 1905 | drivers/block/ide.c | static int ide_ioctl (struct inode *inode, struct file *file, |
inode | 1913 | drivers/block/ide.c | if (!inode || !(inode->i_rdev)) |
inode | 1915 | drivers/block/ide.c | if ((drive = get_info_ptr(inode->i_rdev)) == NULL) |
inode | 1928 | drivers/block/ide.c | put_user((unsigned)drive->part[MINOR(inode->i_rdev)&PARTN_MASK].start_sect, |
inode | 1934 | drivers/block/ide.c | fsync_dev(inode->i_rdev); |
inode | 1935 | drivers/block/ide.c | invalidate_buffers(inode->i_rdev); |
inode | 1941 | drivers/block/ide.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 1945 | drivers/block/ide.c | return write_fs_long(arg, read_ahead[MAJOR(inode->i_rdev)]); |
inode | 1948 | drivers/block/ide.c | return write_fs_long(arg, drive->part[MINOR(inode->i_rdev)&PARTN_MASK].nr_sects); |
inode | 1951 | drivers/block/ide.c | return revalidate_disk(inode->i_rdev); |
inode | 1969 | drivers/block/ide.c | if (!arg || (MINOR(inode->i_rdev) & PARTN_MASK)) |
inode | 1996 | drivers/block/ide.c | if ((MINOR(inode->i_rdev) & PARTN_MASK)) |
inode | 2036 | drivers/block/ide.c | if (MINOR(inode->i_rdev) & PARTN_MASK) |
inode | 2083 | drivers/block/ide.c | if (MINOR(inode->i_rdev) & PARTN_MASK) |
inode | 2094 | drivers/block/ide.c | RO_IOCTLS(inode->i_rdev, arg); |
inode | 2099 | drivers/block/ide.c | return ide_cdrom_ioctl(drive, inode, file, cmd, arg); |
inode | 2103 | drivers/block/ide.c | return idetape_blkdev_ioctl(drive, inode, file, cmd, arg); |
inode | 607 | drivers/block/ide.h | int ide_cdrom_ioctl (ide_drive_t *, struct inode *, struct file *, unsigned int, unsigned long); |
inode | 609 | drivers/block/ide.h | int ide_cdrom_open (struct inode *, struct file *, ide_drive_t *); |
inode | 610 | drivers/block/ide.h | void ide_cdrom_release (struct inode *, struct file *, ide_drive_t *); |
inode | 658 | drivers/block/ide.h | int idetape_blkdev_ioctl (ide_drive_t *drive, struct inode *inode, struct file *file, |
inode | 660 | drivers/block/ide.h | int idetape_blkdev_open (struct inode *inode, struct file *filp, ide_drive_t *drive); |
inode | 661 | drivers/block/ide.h | void idetape_blkdev_release (struct inode *inode, struct file *filp, ide_drive_t *drive); |
inode | 246 | drivers/block/loop.c | struct inode *inode; |
inode | 252 | drivers/block/loop.c | inode = file->f_inode; |
inode | 253 | drivers/block/loop.c | if (!inode) { |
inode | 257 | drivers/block/loop.c | if (S_ISBLK(inode->i_mode)) { |
inode | 258 | drivers/block/loop.c | int error = blkdev_open(inode, file); |
inode | 261 | drivers/block/loop.c | lo->lo_device = inode->i_rdev; |
inode | 263 | drivers/block/loop.c | } else if (S_ISREG(inode->i_mode)) { |
inode | 264 | drivers/block/loop.c | lo->lo_device = inode->i_dev; |
inode | 269 | drivers/block/loop.c | if (IS_RDONLY (inode) || is_read_only(lo->lo_device)) { |
inode | 273 | drivers/block/loop.c | invalidate_inode_pages (inode); |
inode | 277 | drivers/block/loop.c | lo->lo_inode = inode; |
inode | 375 | drivers/block/loop.c | static int lo_ioctl(struct inode * inode, struct file * file, |
inode | 381 | drivers/block/loop.c | if (!inode) |
inode | 383 | drivers/block/loop.c | if (MAJOR(inode->i_rdev) != MAJOR_NR) { |
inode | 387 | drivers/block/loop.c | dev = MINOR(inode->i_rdev); |
inode | 393 | drivers/block/loop.c | return loop_set_fd(lo, inode->i_rdev, arg); |
inode | 395 | drivers/block/loop.c | return loop_clr_fd(lo, inode->i_rdev); |
inode | 415 | drivers/block/loop.c | static int lo_open(struct inode *inode, struct file *file) |
inode | 420 | drivers/block/loop.c | if (!inode) |
inode | 422 | drivers/block/loop.c | if (MAJOR(inode->i_rdev) != MAJOR_NR) { |
inode | 426 | drivers/block/loop.c | dev = MINOR(inode->i_rdev); |
inode | 435 | drivers/block/loop.c | static void lo_release(struct inode *inode, struct file *file) |
inode | 440 | drivers/block/loop.c | if (!inode) |
inode | 442 | drivers/block/loop.c | if (MAJOR(inode->i_rdev) != MAJOR_NR) { |
inode | 446 | drivers/block/loop.c | dev = MINOR(inode->i_rdev); |
inode | 449 | drivers/block/loop.c | fsync_dev(inode->i_rdev); |
inode | 123 | drivers/block/md.c | static int md_ioctl (struct inode *inode, struct file *file, |
inode | 134 | drivers/block/md.c | if (((minor=MINOR(inode->i_rdev)) & 0x80) && |
inode | 138 | drivers/block/md.c | return (pers[minor & 0x7f]->ioctl (inode, file, cmd, arg)); |
inode | 164 | drivers/block/md.c | devices[minor][index].inode=get_empty_inode (); |
inode | 165 | drivers/block/md.c | devices[minor][index].inode->i_dev=dev; /* don't care about |
inode | 167 | drivers/block/md.c | insert_inode_hash (devices[minor][index].inode); |
inode | 243 | drivers/block/md.c | if (inode->i_count>1 || md_dev[minor].busy>1) /* ioctl : one open channel */ |
inode | 245 | drivers/block/md.c | printk ("STOP_MD md%x failed : i_count=%d, busy=%d\n", minor, inode->i_count, md_dev[minor].busy); |
inode | 252 | drivers/block/md.c | fsync_dev (inode->i_rdev); |
inode | 253 | drivers/block/md.c | invalidate_buffers (inode->i_rdev); |
inode | 259 | drivers/block/md.c | clear_inode (devices[minor][index].inode); |
inode | 290 | drivers/block/md.c | put_user (md_hd_struct[MINOR(inode->i_rdev)].nr_sects, (long *) arg); |
inode | 294 | drivers/block/md.c | fsync_dev (inode->i_rdev); |
inode | 295 | drivers/block/md.c | invalidate_buffers (inode->i_rdev); |
inode | 301 | drivers/block/md.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 309 | drivers/block/md.c | put_user (read_ahead[MAJOR(inode->i_rdev)], (long *) arg); |
inode | 320 | drivers/block/md.c | put_user (md_hd_struct[MINOR(inode->i_rdev)].start_sect, |
inode | 324 | drivers/block/md.c | RO_IOCTLS(inode->i_rdev,arg); |
inode | 335 | drivers/block/md.c | static int md_open (struct inode *inode, struct file *file) |
inode | 337 | drivers/block/md.c | int minor=MINOR(inode->i_rdev); |
inode | 344 | drivers/block/md.c | static void md_release (struct inode *inode, struct file *file) |
inode | 346 | drivers/block/md.c | int minor=MINOR(inode->i_rdev); |
inode | 348 | drivers/block/md.c | sync_dev (inode->i_rdev); |
inode | 149 | drivers/block/rd.c | static int rd_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg) |
inode | 153 | drivers/block/rd.c | if (!inode || !inode->i_rdev) |
inode | 159 | drivers/block/rd.c | invalidate_buffers(inode->i_rdev); |
inode | 167 | drivers/block/rd.c | put_user(rd_length[MINOR(inode->i_rdev)] / 512, |
inode | 181 | drivers/block/rd.c | static int initrd_read(struct inode *inode,struct file *file,char *buf, |
inode | 195 | drivers/block/rd.c | static void initrd_release(struct inode *inode,struct file *file) |
inode | 222 | drivers/block/rd.c | static int rd_open(struct inode * inode, struct file * filp) |
inode | 225 | drivers/block/rd.c | if (DEVICE_NR(inode->i_rdev) == INITRD_MINOR) { |
inode | 233 | drivers/block/rd.c | if (DEVICE_NR(inode->i_rdev) >= NUM_RAMDISKS) |
inode | 242 | drivers/block/rd.c | static void rd_release(struct inode * inode, struct file * filp) |
inode | 425 | drivers/block/rd.c | struct inode inode, out_inode; |
inode | 437 | drivers/block/rd.c | memset(&inode, 0, sizeof(inode)); |
inode | 438 | drivers/block/rd.c | inode.i_rdev = device; |
inode | 440 | drivers/block/rd.c | infile.f_inode = &inode; |
inode | 448 | drivers/block/rd.c | if (blkdev_open(&inode, &infile) != 0) return; |
inode | 505 | drivers/block/rd.c | infile.f_op->release(&inode, &infile); |
inode | 193 | drivers/block/xd.c | static int xd_open (struct inode *inode,struct file *file) |
inode | 195 | drivers/block/xd.c | int dev = DEVICE_NR(inode->i_rdev); |
inode | 240 | drivers/block/xd.c | static int xd_ioctl (struct inode *inode,struct file *file,u_int cmd,u_long arg) |
inode | 243 | drivers/block/xd.c | int dev = DEVICE_NR(inode->i_rdev),err; |
inode | 245 | drivers/block/xd.c | if (inode && (dev < xd_drives)) |
inode | 254 | drivers/block/xd.c | put_user(xd[MINOR(inode->i_rdev)].start_sect,&geometry->start); |
inode | 262 | drivers/block/xd.c | if(!(inode->i_rdev)) |
inode | 266 | drivers/block/xd.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 272 | drivers/block/xd.c | put_user(xd[MINOR(inode->i_rdev)].nr_sects,(long *) arg); |
inode | 279 | drivers/block/xd.c | if(!(inode->i_rdev)) |
inode | 281 | drivers/block/xd.c | fsync_dev(inode->i_rdev); |
inode | 282 | drivers/block/xd.c | invalidate_buffers(inode->i_rdev); |
inode | 286 | drivers/block/xd.c | return (xd_reread_partitions(inode->i_rdev)); |
inode | 287 | drivers/block/xd.c | RO_IOCTLS(inode->i_rdev,arg); |
inode | 293 | drivers/block/xd.c | static void xd_release (struct inode *inode, struct file *file) |
inode | 295 | drivers/block/xd.c | int dev = DEVICE_NR(inode->i_rdev); |
inode | 298 | drivers/block/xd.c | sync_dev(inode->i_rdev); |
inode | 611 | drivers/cdrom/aztcd.c | static int aztcd_ioctl(struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg) |
inode | 1455 | drivers/cdrom/aztcd.c | int aztcd_open(struct inode *ip, struct file *fp) |
inode | 1499 | drivers/cdrom/aztcd.c | static void aztcd_release(struct inode * inode, struct file * file) |
inode | 1503 | drivers/cdrom/aztcd.c | printk("inode: %p, inode->i_rdev: %x file: %p\n",inode,inode->i_rdev,file); |
inode | 1508 | drivers/cdrom/aztcd.c | sync_dev(inode->i_rdev); /*??? isn't it a read only dev?*/ |
inode | 1509 | drivers/cdrom/aztcd.c | invalidate_buffers(inode -> i_rdev); |
inode | 236 | drivers/cdrom/cdu31a.c | static int scd_open(struct inode *inode, struct file *filp); |
inode | 1535 | drivers/cdrom/cdu31a.c | struct inode in; |
inode | 2175 | drivers/cdrom/cdu31a.c | struct inode *inode) |
inode | 2205 | drivers/cdrom/cdu31a.c | scd_open (inode, NULL); |
inode | 2378 | drivers/cdrom/cdu31a.c | static int scd_ioctl(struct inode *inode, |
inode | 2389 | drivers/cdrom/cdu31a.c | if (!inode) |
inode | 2704 | drivers/cdrom/cdu31a.c | return(read_audio(&ra, inode)); |
inode | 2726 | drivers/cdrom/cdu31a.c | scd_open(struct inode *inode, |
inode | 2830 | drivers/cdrom/cdu31a.c | check_disk_change(inode->i_rdev); |
inode | 2849 | drivers/cdrom/cdu31a.c | scd_release(struct inode *inode, |
inode | 2863 | drivers/cdrom/cdu31a.c | sync_dev(inode->i_rdev); |
inode | 532 | drivers/cdrom/cm206.c | static int cm206_open(struct inode *ip, struct file *fp) |
inode | 569 | drivers/cdrom/cm206.c | static void cm206_release(struct inode *ip, struct file *fp) |
inode | 885 | drivers/cdrom/cm206.c | static int cm206_ioctl(struct inode * inode, struct file * file, |
inode | 87 | drivers/cdrom/gscd.c | static int gscd_ioctl (struct inode *, struct file *, unsigned int, unsigned long); |
inode | 88 | drivers/cdrom/gscd.c | static int gscd_open (struct inode *, struct file *); |
inode | 89 | drivers/cdrom/gscd.c | static void gscd_release (struct inode *, struct file *); |
inode | 202 | drivers/cdrom/gscd.c | static int gscd_ioctl (struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg) |
inode | 362 | drivers/cdrom/gscd.c | static int gscd_open (struct inode *ip, struct file *fp) |
inode | 395 | drivers/cdrom/gscd.c | static void gscd_release (struct inode * inode, struct file * file) |
inode | 403 | drivers/cdrom/gscd.c | sync_dev(inode->i_rdev); |
inode | 404 | drivers/cdrom/gscd.c | invalidate_buffers(inode -> i_rdev); |
inode | 286 | drivers/cdrom/mcd.c | mcd_ioctl(struct inode *ip, struct file *fp, unsigned int cmd, |
inode | 1095 | drivers/cdrom/mcd.c | mcd_open(struct inode *ip, struct file *fp) |
inode | 1134 | drivers/cdrom/mcd.c | mcd_release(struct inode * inode, struct file * file) |
inode | 1138 | drivers/cdrom/mcd.c | sync_dev(inode->i_rdev); |
inode | 1139 | drivers/cdrom/mcd.c | invalidate_buffers(inode -> i_rdev); |
inode | 206 | drivers/cdrom/mcdx.c | static int mcdx_open(struct inode*, struct file*); |
inode | 207 | drivers/cdrom/mcdx.c | static void mcdx_close(struct inode*, struct file*); |
inode | 208 | drivers/cdrom/mcdx.c | static int mcdx_ioctl(struct inode*, struct file*, unsigned int, unsigned long); |
inode | 278 | drivers/cdrom/mcdx.c | struct inode* ip, struct file* fp, |
inode | 622 | drivers/cdrom/mcdx.c | mcdx_open(struct inode *ip, struct file *fp) |
inode | 790 | drivers/cdrom/mcdx.c | mcdx_close(struct inode *ip, struct file *fp) |
inode | 1734 | drivers/cdrom/optcd.c | static int opt_ioctl(struct inode *ip, struct file *fp, |
inode | 1865 | drivers/cdrom/optcd.c | static int opt_open(struct inode *ip, struct file *fp) |
inode | 1915 | drivers/cdrom/optcd.c | static void opt_release(struct inode *ip, struct file *fp) |
inode | 3831 | drivers/cdrom/sbpcd.c | static int sbpcd_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 3837 | drivers/cdrom/sbpcd.c | MINOR(inode->i_rdev), cmd, arg); |
inode | 3838 | drivers/cdrom/sbpcd.c | if (!inode) return (-EINVAL); |
inode | 3839 | drivers/cdrom/sbpcd.c | i=MINOR(inode->i_rdev); |
inode | 3842 | drivers/cdrom/sbpcd.c | msg(DBG_INF, "ioctl: bad device: %04X\n", inode->i_rdev); |
inode | 4377 | drivers/cdrom/sbpcd.c | if(!(inode->i_rdev)) return -EINVAL; |
inode | 4379 | drivers/cdrom/sbpcd.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 4881 | drivers/cdrom/sbpcd.c | static int sbpcd_open(struct inode *ip, struct file *fp) |
inode | 4966 | drivers/cdrom/sbpcd.c | static void sbpcd_release(struct inode * ip, struct file * file) |
inode | 653 | drivers/cdrom/sjcd.c | static int sjcd_ioctl( struct inode *ip, struct file *fp, |
inode | 1309 | drivers/cdrom/sjcd.c | int sjcd_open( struct inode *ip, struct file *fp ){ |
inode | 1384 | drivers/cdrom/sjcd.c | static void sjcd_release( struct inode *inode, struct file *file ){ |
inode | 1395 | drivers/cdrom/sjcd.c | sync_dev( inode->i_rdev ); |
inode | 1396 | drivers/cdrom/sjcd.c | invalidate_buffers( inode->i_rdev ); |
inode | 192 | drivers/cdrom/sonycd535.c | static int cdu_open(struct inode *inode, struct file *filp); |
inode | 1071 | drivers/cdrom/sonycd535.c | cdu_ioctl(struct inode *inode, |
inode | 1083 | drivers/cdrom/sonycd535.c | if (!inode) { |
inode | 1086 | drivers/cdrom/sonycd535.c | dev = MINOR(inode->i_rdev) >> 6; |
inode | 1389 | drivers/cdrom/sonycd535.c | cdu_open(struct inode *inode, |
inode | 1417 | drivers/cdrom/sonycd535.c | if (inode) { |
inode | 1418 | drivers/cdrom/sonycd535.c | check_disk_change(inode->i_rdev); |
inode | 1437 | drivers/cdrom/sonycd535.c | cdu_release(struct inode *inode, |
inode | 1449 | drivers/cdrom/sonycd535.c | sync_dev(inode->i_rdev); |
inode | 156 | drivers/char/amigamouse.c | static int fasync_mouse(struct inode *inode, struct file *filp, int on) |
inode | 160 | drivers/char/amigamouse.c | retval = fasync_helper(inode, filp, on, &mouse.fasyncptr); |
inode | 170 | drivers/char/amigamouse.c | static void close_mouse(struct inode * inode, struct file * file) |
inode | 172 | drivers/char/amigamouse.c | fasync_mouse(inode, file, 0); |
inode | 184 | drivers/char/amigamouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 204 | drivers/char/amigamouse.c | static int write_mouse(struct inode * inode, struct file * file, const char * buffer, int count) |
inode | 213 | drivers/char/amigamouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 265 | drivers/char/amigamouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 297 | drivers/char/apm_bios.c | static int do_open(struct inode *, struct file *); |
inode | 298 | drivers/char/apm_bios.c | static void do_release(struct inode *, struct file *); |
inode | 299 | drivers/char/apm_bios.c | static int do_read(struct inode *, struct file *, char *, int); |
inode | 300 | drivers/char/apm_bios.c | static int do_select(struct inode *, struct file *, int, |
inode | 302 | drivers/char/apm_bios.c | static int do_ioctl(struct inode *, struct file *, u_int, u_long); |
inode | 806 | drivers/char/apm_bios.c | static int do_read(struct inode *inode, struct file *fp, char *buf, int count) |
inode | 846 | drivers/char/apm_bios.c | static int do_select(struct inode *inode, struct file *fp, int sel_type, |
inode | 862 | drivers/char/apm_bios.c | static int do_ioctl(struct inode * inode, struct file *filp, |
inode | 893 | drivers/char/apm_bios.c | static void do_release(struct inode * inode, struct file * filp) |
inode | 928 | drivers/char/apm_bios.c | static int do_open(struct inode * inode, struct file * filp) |
inode | 54 | drivers/char/atarimouse.c | static int fasync_mouse(struct inode *inode, struct file *filp, int on) |
inode | 58 | drivers/char/atarimouse.c | retval = fasync_helper(inode, filp, on, &mouse.fasyncptr); |
inode | 64 | drivers/char/atarimouse.c | static void release_mouse(struct inode *inode, struct file *file) |
inode | 66 | drivers/char/atarimouse.c | fasync_mouse(inode, file, 0); |
inode | 75 | drivers/char/atarimouse.c | static int open_mouse(struct inode *inode, struct file *file) |
inode | 90 | drivers/char/atarimouse.c | static int write_mouse(struct inode *inode, struct file *file, const char *buffer, int count) |
inode | 95 | drivers/char/atarimouse.c | static int read_mouse(struct inode *inode, struct file *file, char *buffer, int count) |
inode | 131 | drivers/char/atarimouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table *wait) |
inode | 96 | drivers/char/atixlmouse.c | static int fasync_mouse(struct inode *inode, struct file *filp, int on) |
inode | 100 | drivers/char/atixlmouse.c | retval = fasync_helper(inode, filp, on, &mouse.fasync); |
inode | 106 | drivers/char/atixlmouse.c | static void release_mouse(struct inode * inode, struct file * file) |
inode | 108 | drivers/char/atixlmouse.c | fasync_mouse(inode, file, 0); |
inode | 117 | drivers/char/atixlmouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 137 | drivers/char/atixlmouse.c | static int write_mouse(struct inode * inode, struct file * file, const char * buffer, int count) |
inode | 142 | drivers/char/atixlmouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 173 | drivers/char/atixlmouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 107 | drivers/char/busmouse.c | static int fasync_mouse(struct inode *inode, struct file *filp, int on) |
inode | 111 | drivers/char/busmouse.c | retval = fasync_helper(inode, filp, on, &mouse.fasyncptr); |
inode | 121 | drivers/char/busmouse.c | static void close_mouse(struct inode * inode, struct file * file) |
inode | 123 | drivers/char/busmouse.c | fasync_mouse(inode, file, 0); |
inode | 135 | drivers/char/busmouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 158 | drivers/char/busmouse.c | static int write_mouse(struct inode * inode, struct file * file, const char * buffer, int count) |
inode | 167 | drivers/char/busmouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 219 | drivers/char/busmouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 55 | drivers/char/fbmem.c | fb_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 58 | drivers/char/fbmem.c | struct fb_ops *fb = registered_fb[GET_FB_IDX(inode->i_rdev)]; |
inode | 77 | drivers/char/fbmem.c | fb_write(struct inode *inode, struct file *file, const char *buf, int count) |
inode | 80 | drivers/char/fbmem.c | struct fb_ops *fb = registered_fb[GET_FB_IDX(inode->i_rdev)]; |
inode | 99 | drivers/char/fbmem.c | fb_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 102 | drivers/char/fbmem.c | struct fb_ops *fb = registered_fb[GET_FB_IDX(inode->i_rdev)]; |
inode | 116 | drivers/char/fbmem.c | fbidx=GET_FB_IDX(inode->i_rdev); |
inode | 117 | drivers/char/fbmem.c | vidx=GET_FB_VAR_IDX(inode->i_rdev); |
inode | 131 | drivers/char/fbmem.c | fbidx=GET_FB_IDX(inode->i_rdev); |
inode | 132 | drivers/char/fbmem.c | vidx=GET_FB_VAR_IDX(inode->i_rdev); |
inode | 184 | drivers/char/fbmem.c | return (fb->fb_ioctl(inode, file, cmd, arg, PROC_CONSOLE())); |
inode | 189 | drivers/char/fbmem.c | fb_mmap(struct inode *inode, struct file *file, struct vm_area_struct * vma) |
inode | 191 | drivers/char/fbmem.c | struct fb_ops *fb = registered_fb[GET_FB_IDX(inode->i_rdev)]; |
inode | 207 | drivers/char/fbmem.c | vma->vm_inode = inode; |
inode | 208 | drivers/char/fbmem.c | inode->i_count++; |
inode | 213 | drivers/char/fbmem.c | fb_open(struct inode *inode, struct file *file) |
inode | 215 | drivers/char/fbmem.c | int fbidx=GET_FB_IDX(inode->i_rdev); |
inode | 216 | drivers/char/fbmem.c | int vidx=GET_FB_VAR_IDX(inode->i_rdev); |
inode | 235 | drivers/char/fbmem.c | fb_release(struct inode *inode, struct file *file) |
inode | 237 | drivers/char/fbmem.c | int fbidx=GET_FB_IDX(inode->i_rdev); |
inode | 238 | drivers/char/fbmem.c | int vidx=GET_FB_VAR_IDX(inode->i_rdev); |
inode | 60 | drivers/char/ftape/kernel-interface.c | static int ftape_open(struct inode *ino, struct file *filep); |
inode | 61 | drivers/char/ftape/kernel-interface.c | static void ftape_close(struct inode *ino, struct file *filep); |
inode | 62 | drivers/char/ftape/kernel-interface.c | static int ftape_ioctl(struct inode *ino, struct file *filep, |
inode | 64 | drivers/char/ftape/kernel-interface.c | static int ftape_read(struct inode *ino, struct file *fp, char *buff, |
inode | 66 | drivers/char/ftape/kernel-interface.c | static int ftape_write(struct inode *ino, struct file *fp, const char *buff, |
inode | 215 | drivers/char/ftape/kernel-interface.c | static int ftape_open(struct inode *ino, struct file *filep) |
inode | 264 | drivers/char/ftape/kernel-interface.c | static void ftape_close(struct inode *ino, struct file *filep) |
inode | 289 | drivers/char/ftape/kernel-interface.c | static int ftape_ioctl(struct inode *ino, struct file *filep, |
inode | 313 | drivers/char/ftape/kernel-interface.c | static int ftape_read(struct inode *ino, struct file *fp, char *buff, int req_len) |
inode | 336 | drivers/char/ftape/kernel-interface.c | static int ftape_write(struct inode *ino, struct file *fp, const char *buff, int req_len) |
inode | 541 | drivers/char/istallion.c | static int stli_memread(struct inode *ip, struct file *fp, char *buf, int count); |
inode | 542 | drivers/char/istallion.c | static int stli_memwrite(struct inode *ip, struct file *fp, const char *buf, int count); |
inode | 543 | drivers/char/istallion.c | static int stli_memioctl(struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg); |
inode | 4048 | drivers/char/istallion.c | static int stli_memread(struct inode *ip, struct file *fp, char *buf, int count) |
inode | 4097 | drivers/char/istallion.c | static int stli_memwrite(struct inode *ip, struct file *fp, const char *buf, int count) |
inode | 4362 | drivers/char/istallion.c | static int stli_memioctl(struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg) |
inode | 298 | drivers/char/lp.c | static int lp_write(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 300 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 312 | drivers/char/lp.c | static int lp_lseek(struct inode * inode, struct file * file, |
inode | 318 | drivers/char/lp.c | static int lp_open(struct inode * inode, struct file * file) |
inode | 320 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 376 | drivers/char/lp.c | static void lp_release(struct inode * inode, struct file * file) |
inode | 378 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 392 | drivers/char/lp.c | static int lp_ioctl(struct inode *inode, struct file *file, |
inode | 395 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 177 | drivers/char/lp_m68k.c | static int lp_write(struct inode *inode, struct file *file, |
inode | 180 | drivers/char/lp_m68k.c | static int lp_write_interrupt(struct inode *inode, struct file *file, |
inode | 187 | drivers/char/lp_m68k.c | int dev = MINOR(inode->i_rdev); |
inode | 269 | drivers/char/lp_m68k.c | static int lp_write(struct inode *inode, struct file *file, |
inode | 272 | drivers/char/lp_m68k.c | static int lp_write_polled(struct inode *inode, struct file *file, |
inode | 277 | drivers/char/lp_m68k.c | int dev = MINOR(inode->i_rdev); |
inode | 345 | drivers/char/lp_m68k.c | static int lp_write(struct inode *inode, struct file *file, |
inode | 349 | drivers/char/lp_m68k.c | return lp_write_interrupt(inode, file, buf, count); |
inode | 351 | drivers/char/lp_m68k.c | return lp_write_polled(inode, file, buf, count); |
inode | 355 | drivers/char/lp_m68k.c | static int lp_lseek(struct inode *inode, struct file *file, |
inode | 361 | drivers/char/lp_m68k.c | static int lp_open(struct inode *inode, struct file *file) |
inode | 363 | drivers/char/lp_m68k.c | int dev = MINOR(inode->i_rdev); |
inode | 377 | drivers/char/lp_m68k.c | static void lp_release(struct inode *inode, struct file *file) |
inode | 379 | drivers/char/lp_m68k.c | lp_table[MINOR(inode->i_rdev)].flags &= ~LP_BUSY; |
inode | 383 | drivers/char/lp_m68k.c | static int lp_ioctl(struct inode *inode, struct file *file, |
inode | 386 | drivers/char/lp_m68k.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 33 | drivers/char/mem.c | static int read_ram(struct inode * inode, struct file * file, char * buf, int count) |
inode | 38 | drivers/char/mem.c | static int write_ram(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 43 | drivers/char/mem.c | static int read_mem(struct inode * inode, struct file * file, char * buf, int count) |
inode | 71 | drivers/char/mem.c | static int write_mem(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 99 | drivers/char/mem.c | static int mmap_mem(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 115 | drivers/char/mem.c | vma->vm_inode = inode; |
inode | 116 | drivers/char/mem.c | inode->i_count++; |
inode | 120 | drivers/char/mem.c | static int read_kmem(struct inode *inode, struct file *file, char *buf, int count) |
inode | 124 | drivers/char/mem.c | read1 = read_mem(inode, file, buf, count); |
inode | 134 | drivers/char/mem.c | static int read_port(struct inode * inode, struct file * file,char * buf, int count) |
inode | 148 | drivers/char/mem.c | static int write_port(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 162 | drivers/char/mem.c | static int read_null(struct inode * node, struct file * file, char * buf, int count) |
inode | 167 | drivers/char/mem.c | static int write_null(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 172 | drivers/char/mem.c | static int read_zero(struct inode * node, struct file * file, char * buf, int count) |
inode | 183 | drivers/char/mem.c | static int mmap_zero(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 192 | drivers/char/mem.c | static int read_full(struct inode * node, struct file * file, char * buf,int count) |
inode | 197 | drivers/char/mem.c | static int write_full(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 207 | drivers/char/mem.c | static int null_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 219 | drivers/char/mem.c | static int memory_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 330 | drivers/char/mem.c | static int memory_open(struct inode * inode, struct file * filp) |
inode | 332 | drivers/char/mem.c | switch (MINOR(inode->i_rdev)) { |
inode | 364 | drivers/char/mem.c | return filp->f_op->open(inode,filp); |
inode | 86 | drivers/char/misc.c | static int misc_open(struct inode * inode, struct file * file) |
inode | 88 | drivers/char/misc.c | int minor = MINOR(inode->i_rdev); |
inode | 108 | drivers/char/misc.c | return file->f_op->open(inode,file); |
inode | 83 | drivers/char/msbusmouse.c | static int fasync_mouse(struct inode *inode, struct file *filp, int on) |
inode | 87 | drivers/char/msbusmouse.c | retval = fasync_helper(inode, filp, on, &mouse.fasyncptr); |
inode | 93 | drivers/char/msbusmouse.c | static void release_mouse(struct inode * inode, struct file * file) |
inode | 95 | drivers/char/msbusmouse.c | fasync_mouse(inode, file, 0); |
inode | 104 | drivers/char/msbusmouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 123 | drivers/char/msbusmouse.c | static int write_mouse(struct inode * inode, struct file * file, const char * buffer, int count) |
inode | 128 | drivers/char/msbusmouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 149 | drivers/char/msbusmouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 976 | drivers/char/n_tty.c | static int normal_select(struct tty_struct * tty, struct inode * inode, |
inode | 125 | drivers/char/psaux.c | static int fasync_aux(struct inode *inode, struct file *filp, int on); |
inode | 256 | drivers/char/psaux.c | static void release_aux(struct inode * inode, struct file * file) |
inode | 258 | drivers/char/psaux.c | fasync_aux(inode, file, 0); |
inode | 270 | drivers/char/psaux.c | static void release_qp(struct inode * inode, struct file * file) |
inode | 274 | drivers/char/psaux.c | fasync_aux(inode, file, 0); |
inode | 288 | drivers/char/psaux.c | static int fasync_aux(struct inode *inode, struct file *filp, int on) |
inode | 292 | drivers/char/psaux.c | retval = fasync_helper(inode, filp, on, &queue->fasync); |
inode | 303 | drivers/char/psaux.c | static int open_aux(struct inode * inode, struct file * file) |
inode | 334 | drivers/char/psaux.c | static int open_qp(struct inode * inode, struct file * file) |
inode | 378 | drivers/char/psaux.c | static int write_aux(struct inode * inode, struct file * file, const char * buffer, int count) |
inode | 390 | drivers/char/psaux.c | inode->i_mtime = CURRENT_TIME; |
inode | 400 | drivers/char/psaux.c | static int write_qp(struct inode * inode, struct file * file, const char * buffer, int count) |
inode | 409 | drivers/char/psaux.c | inode->i_mtime = CURRENT_TIME; |
inode | 419 | drivers/char/psaux.c | static int read_aux(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 445 | drivers/char/psaux.c | inode->i_atime = CURRENT_TIME; |
inode | 454 | drivers/char/psaux.c | static int aux_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 234 | drivers/char/random.c | static int random_read(struct inode * inode, struct file * file, |
inode | 236 | drivers/char/random.c | static int random_read_unlimited(struct inode * inode, struct file * file, |
inode | 238 | drivers/char/random.c | static int random_select(struct inode *inode, struct file *file, |
inode | 240 | drivers/char/random.c | static int random_write(struct inode * inode, struct file * file, |
inode | 242 | drivers/char/random.c | static int random_ioctl(struct inode * inode, struct file * file, |
inode | 646 | drivers/char/random.c | random_read(struct inode * inode, struct file * file, char * buf, int nbytes) |
inode | 689 | drivers/char/random.c | random_read_unlimited(struct inode * inode, struct file * file, |
inode | 696 | drivers/char/random.c | random_select(struct inode *inode, struct file *file, |
inode | 708 | drivers/char/random.c | random_write(struct inode * inode, struct file * file, |
inode | 725 | drivers/char/random.c | if (inode) |
inode | 726 | drivers/char/random.c | inode->i_mtime = CURRENT_TIME; |
inode | 731 | drivers/char/random.c | random_ioctl(struct inode * inode, struct file * file, |
inode | 70 | drivers/char/rtc.c | static int rtc_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 73 | drivers/char/rtc.c | static int rtc_read(struct inode *inode, struct file *file, |
inode | 76 | drivers/char/rtc.c | static int rtc_ioctl(struct inode *inode, struct file *file, |
inode | 79 | drivers/char/rtc.c | static int rtc_select(struct inode *inode, struct file *file, |
inode | 128 | drivers/char/rtc.c | static int rtc_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 134 | drivers/char/rtc.c | static int rtc_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 175 | drivers/char/rtc.c | static int rtc_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 452 | drivers/char/rtc.c | static int rtc_open(struct inode *inode, struct file *file) |
inode | 463 | drivers/char/rtc.c | static void rtc_release(struct inode *inode, struct file *file) |
inode | 487 | drivers/char/rtc.c | static int rtc_select(struct inode *inode, struct file *file, |
inode | 54 | drivers/char/softdog.c | static int softdog_open(struct inode *inode, struct file *file) |
inode | 67 | drivers/char/softdog.c | static void softdog_release(struct inode *inode, struct file *file) |
inode | 78 | drivers/char/softdog.c | static int softdog_write(struct inode *inode, struct file *file, const char *data, int len) |
inode | 396 | drivers/char/stallion.c | static int stl_memioctl(struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg); |
inode | 3066 | drivers/char/stallion.c | static int stl_memioctl(struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg) |
inode | 1881 | drivers/char/tpqic02.c | static int qic02_tape_lseek(struct inode * inode, struct file * file, off_t offset, int origin) |
inode | 1919 | drivers/char/tpqic02.c | static int qic02_tape_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 1922 | drivers/char/tpqic02.c | kdev_t dev = inode->i_rdev; |
inode | 2094 | drivers/char/tpqic02.c | static int qic02_tape_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 2097 | drivers/char/tpqic02.c | kdev_t dev = inode->i_rdev; |
inode | 2246 | drivers/char/tpqic02.c | static int qic02_tape_open(struct inode * inode, struct file * filp) |
inode | 2248 | drivers/char/tpqic02.c | kdev_t dev = inode->i_rdev; |
inode | 2432 | drivers/char/tpqic02.c | static void qic02_tape_release(struct inode * inode, struct file * filp) |
inode | 2434 | drivers/char/tpqic02.c | kdev_t dev = inode->i_rdev; |
inode | 2554 | drivers/char/tpqic02.c | static int qic02_tape_ioctl(struct inode * inode, struct file * filp, |
inode | 2559 | drivers/char/tpqic02.c | int dev_maj = MAJOR(inode->i_rdev); |
inode | 2570 | drivers/char/tpqic02.c | if (!inode || !ioarg) |
inode | 113 | drivers/char/tty_io.c | static int tty_read(struct inode *, struct file *, char *, int); |
inode | 114 | drivers/char/tty_io.c | static int tty_write(struct inode *, struct file *, const char *, int); |
inode | 115 | drivers/char/tty_io.c | static int tty_select(struct inode *, struct file *, int, select_table *); |
inode | 116 | drivers/char/tty_io.c | static int tty_open(struct inode *, struct file *); |
inode | 117 | drivers/char/tty_io.c | static void tty_release(struct inode *, struct file *); |
inode | 118 | drivers/char/tty_io.c | static int tty_ioctl(struct inode * inode, struct file * file, |
inode | 120 | drivers/char/tty_io.c | static int tty_fasync(struct inode * inode, struct file * filp, int on); |
inode | 315 | drivers/char/tty_io.c | static int hung_up_tty_read(struct inode * inode, struct file * file, char * buf, int count) |
inode | 320 | drivers/char/tty_io.c | static int hung_up_tty_write(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 325 | drivers/char/tty_io.c | static int hung_up_tty_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 330 | drivers/char/tty_io.c | static int hung_up_tty_ioctl(struct inode * inode, struct file * file, |
inode | 336 | drivers/char/tty_io.c | static int tty_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 718 | drivers/char/tty_io.c | static int tty_read(struct inode * inode, struct file * file, char * buf, int count) |
inode | 724 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_read")) |
inode | 734 | drivers/char/tty_io.c | if ((inode->i_rdev != CONSOLE_DEV) && /* don't stop on /dev/console */ |
inode | 751 | drivers/char/tty_io.c | inode->i_atime = CURRENT_TIME; |
inode | 755 | drivers/char/tty_io.c | static int tty_write(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 760 | drivers/char/tty_io.c | is_console = (inode->i_rdev == CONSOLE_DEV); |
inode | 766 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_write")) |
inode | 787 | drivers/char/tty_io.c | inode->i_mtime = CURRENT_TIME; |
inode | 1165 | drivers/char/tty_io.c | static int tty_open(struct inode * inode, struct file * filp) |
inode | 1174 | drivers/char/tty_io.c | device = inode->i_rdev; |
inode | 1240 | drivers/char/tty_io.c | static void tty_release(struct inode * inode, struct file * filp) |
inode | 1245 | drivers/char/tty_io.c | static int tty_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 1250 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_select")) |
inode | 1254 | drivers/char/tty_io.c | return (tty->ldisc.select)(tty, inode, filp, sel_type, wait); |
inode | 1263 | drivers/char/tty_io.c | int fasync_helper(struct inode * inode, struct file * filp, int on, struct fasync_struct **fapp) |
inode | 1298 | drivers/char/tty_io.c | static int tty_fasync(struct inode * inode, struct file * filp, int on) |
inode | 1304 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_fasync")) |
inode | 1307 | drivers/char/tty_io.c | retval = fasync_helper(inode, filp, on, &tty->fasync); |
inode | 1361 | drivers/char/tty_io.c | static int tty_ioctl(struct inode * inode, struct file * file, |
inode | 1373 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_ioctl")) |
inode | 31 | drivers/char/vc_screen.c | vcs_size(struct inode *inode) |
inode | 34 | drivers/char/vc_screen.c | if (MINOR(inode->i_rdev) & 128) |
inode | 40 | drivers/char/vc_screen.c | vcs_lseek(struct inode *inode, struct file *file, off_t offset, int orig) |
inode | 42 | drivers/char/vc_screen.c | int size = vcs_size(inode); |
inode | 63 | drivers/char/vc_screen.c | vcs_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 66 | drivers/char/vc_screen.c | unsigned int cons = MINOR(inode->i_rdev); |
inode | 83 | drivers/char/vc_screen.c | size = vcs_size(inode); |
inode | 121 | drivers/char/vc_screen.c | vcs_write(struct inode *inode, struct file *file, const char *buf, int count) |
inode | 124 | drivers/char/vc_screen.c | unsigned int cons = MINOR(inode->i_rdev); |
inode | 141 | drivers/char/vc_screen.c | size = vcs_size(inode); |
inode | 186 | drivers/char/vc_screen.c | vcs_open(struct inode *inode, struct file *filp) |
inode | 188 | drivers/char/vc_screen.c | unsigned int cons = (MINOR(inode->i_rdev) & 127); |
inode | 108 | drivers/char/wdt.c | static int wdt_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 114 | drivers/char/wdt.c | static int wdt_write(struct inode *inode, struct file *file, const char *buf, int count) |
inode | 128 | drivers/char/wdt.c | static int wdt_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 134 | drivers/char/wdt.c | switch(MINOR(inode->i_rdev)) |
inode | 150 | drivers/char/wdt.c | static int wdt_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 156 | drivers/char/wdt.c | static int wdt_open(struct inode *inode, struct file *file) |
inode | 158 | drivers/char/wdt.c | switch(MINOR(inode->i_rdev)) |
inode | 186 | drivers/char/wdt.c | static void wdt_release(struct inode *inode, struct file *file) |
inode | 188 | drivers/char/wdt.c | if(MINOR(inode->i_rdev)==WATCHDOG_MINOR) |
inode | 737 | drivers/isdn/isdn_common.c | static int isdn_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 739 | drivers/isdn/isdn_common.c | uint minor = MINOR(inode->i_rdev); |
inode | 807 | drivers/isdn/isdn_common.c | static int isdn_lseek(struct inode *inode, struct file *file, off_t offset, int orig) |
inode | 812 | drivers/isdn/isdn_common.c | static int isdn_write(struct inode *inode, struct file *file, const char *buf, int count) |
inode | 814 | drivers/isdn/isdn_common.c | uint minor = MINOR(inode->i_rdev); |
inode | 856 | drivers/isdn/isdn_common.c | static int isdn_select(struct inode *inode, struct file *file, int type, select_table * st) |
inode | 858 | drivers/isdn/isdn_common.c | uint minor = MINOR(inode->i_rdev); |
inode | 1021 | drivers/isdn/isdn_common.c | static int isdn_ioctl(struct inode *inode, struct file *file, uint cmd, ulong arg) |
inode | 1023 | drivers/isdn/isdn_common.c | uint minor = MINOR(inode->i_rdev); |
inode | 1404 | drivers/isdn/isdn_common.c | static int isdn_open(struct inode *ino, struct file *filep) |
inode | 1462 | drivers/isdn/isdn_common.c | static void isdn_close(struct inode *ino, struct file *filep) |
inode | 197 | drivers/net/ppp.c | static int ppp_tty_select (struct tty_struct *tty, struct inode *inode, |
inode | 2582 | drivers/net/ppp.c | ppp_tty_select (struct tty_struct *tty, struct inode *inode, |
inode | 516 | drivers/sbus/char/suncons.c | int (*mmap)(struct inode *, struct file *, struct vm_area_struct *, long fb_base, void *); |
inode | 520 | drivers/sbus/char/suncons.c | int (*ioctl)(struct inode *, struct file *, unsigned int, unsigned long, void *); |
inode | 534 | drivers/sbus/char/suncons.c | fb_open (struct inode * inode, struct file * file) |
inode | 536 | drivers/sbus/char/suncons.c | int minor = MINOR (inode->i_rdev); |
inode | 548 | drivers/sbus/char/suncons.c | fb_ioctl (struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg) |
inode | 550 | drivers/sbus/char/suncons.c | int minor = MINOR (inode->i_rdev); |
inode | 634 | drivers/sbus/char/suncons.c | i = fb->ioctl (inode, file, cmd, arg, fb); |
inode | 646 | drivers/sbus/char/suncons.c | fb_close (struct inode * inode, struct file *filp) |
inode | 648 | drivers/sbus/char/suncons.c | int minor = MINOR(inode->i_rdev); |
inode | 663 | drivers/sbus/char/suncons.c | fb_ioctl (inode, filp, FBIOSCURPOS, (unsigned long) &cursor); |
inode | 670 | drivers/sbus/char/suncons.c | fb_mmap (struct inode *inode, struct file *file, struct vm_area_struct *vma) |
inode | 672 | drivers/sbus/char/suncons.c | int minor = MINOR (inode->i_rdev); |
inode | 688 | drivers/sbus/char/suncons.c | v = (*fb->mmap)(inode, file, vma, fb->base, fb); |
inode | 829 | drivers/sbus/char/suncons.c | cg6_mmap (struct inode *inode, struct file *file, struct vm_area_struct *vma, long base, void *xx) |
inode | 896 | drivers/sbus/char/suncons.c | vma->vm_inode = inode; |
inode | 897 | drivers/sbus/char/suncons.c | inode->i_count++; |
inode | 986 | drivers/sbus/char/suncons.c | cg6_ioctl (struct inode *inode, struct file *file, unsigned cmd, unsigned long arg, fbinfo_t *fb) |
inode | 1082 | drivers/sbus/char/suncons.c | cg3_mmap (struct inode *inode, struct file *file, struct vm_area_struct *vma, long base, void *xx) |
inode | 1119 | drivers/sbus/char/suncons.c | vma->vm_inode = inode; |
inode | 1120 | drivers/sbus/char/suncons.c | inode->i_count++; |
inode | 1160 | drivers/sbus/char/suncons.c | bwtwo_mmap (struct inode *inode, struct file *file, struct vm_area_struct *vma, long base, void *xx) |
inode | 1183 | drivers/sbus/char/suncons.c | vma->vm_inode = inode; |
inode | 1184 | drivers/sbus/char/suncons.c | inode->i_count++; |
inode | 1122 | drivers/sbus/char/sunkbd.c | kbd_read (struct inode *inode, struct file *f, char *buffer, int count) |
inode | 1155 | drivers/sbus/char/sunkbd.c | kbd_fasync (struct inode *inode, struct file *filp, int on) |
inode | 1159 | drivers/sbus/char/sunkbd.c | retval = fasync_helper (inode, filp, on, &kb_fasync); |
inode | 1166 | drivers/sbus/char/sunkbd.c | kbd_select (struct inode *i, struct file *f, int sel_type, select_table *wait) |
inode | 1177 | drivers/sbus/char/sunkbd.c | kbd_ioctl (struct inode *i, struct file *f, unsigned int cmd, unsigned long arg) |
inode | 1233 | drivers/sbus/char/sunkbd.c | kbd_open (struct inode *i, struct file *f) |
inode | 1243 | drivers/sbus/char/sunkbd.c | kbd_close (struct inode *i, struct file *f) |
inode | 260 | drivers/sbus/char/sunmouse.c | sun_mouse_open(struct inode * inode, struct file * file) |
inode | 274 | drivers/sbus/char/sunmouse.c | sun_mouse_fasync (struct inode *inode, struct file *filp, int on) |
inode | 278 | drivers/sbus/char/sunmouse.c | retval = fasync_helper (inode, filp, on, &sunmouse.fasync); |
inode | 285 | drivers/sbus/char/sunmouse.c | sun_mouse_close(struct inode *inode, struct file *file) |
inode | 288 | drivers/sbus/char/sunmouse.c | sun_mouse_fasync (inode, file, 0); |
inode | 292 | drivers/sbus/char/sunmouse.c | sun_mouse_write(struct inode *inode, struct file *file, const char *buffer, |
inode | 299 | drivers/sbus/char/sunmouse.c | sun_mouse_read(struct inode *inode, struct file *file, char *buffer, |
inode | 323 | drivers/sbus/char/sunmouse.c | inode->i_atime = CURRENT_TIME; |
inode | 333 | drivers/sbus/char/sunmouse.c | inode->i_atime = CURRENT_TIME; |
inode | 343 | drivers/sbus/char/sunmouse.c | sun_mouse_select(struct inode *inode, struct file *file, int sel_type, |
inode | 354 | drivers/sbus/char/sunmouse.c | sun_mouse_ioctl (struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg) |
inode | 3202 | drivers/scsi/53c7,8xx.c | static struct Scsi_Host * inode_to_host (struct inode *inode) { |
inode | 3205 | drivers/scsi/53c7,8xx.c | for (dev = MINOR(inode->rdev), host = first_host; |
inode | 3213 | drivers/scsi/53c7,8xx.c | debugger_user_write (struct inode *inode,struct file *filp, |
inode | 3222 | drivers/scsi/53c7,8xx.c | if (!(host = inode_to_host(inode))) |
inode | 3266 | drivers/scsi/53c7,8xx.c | debugger_user_read (struct inode *inode,struct file *filp, |
inode | 631 | drivers/scsi/scsi_debug.c | int length, int inode, int inout) |
inode | 51 | drivers/scsi/scsi_proc.c | int length, int inode, int inout) |
inode | 72 | drivers/scsi/sd.c | extern int sd_ioctl(struct inode *, struct file *, unsigned int, unsigned long); |
inode | 94 | drivers/scsi/sd.c | static int sd_open(struct inode * inode, struct file * filp) |
inode | 97 | drivers/scsi/sd.c | target = DEVICE_NR(inode->i_rdev); |
inode | 111 | drivers/scsi/sd.c | check_disk_change(inode->i_rdev); |
inode | 130 | drivers/scsi/sd.c | sd_ioctl(inode, NULL, SCSI_IOCTL_DOORLOCK, 0); |
inode | 137 | drivers/scsi/sd.c | if(sd_sizes[MINOR(inode->i_rdev)] == 0) |
inode | 147 | drivers/scsi/sd.c | static void sd_release(struct inode * inode, struct file * file) |
inode | 150 | drivers/scsi/sd.c | fsync_dev(inode->i_rdev); |
inode | 152 | drivers/scsi/sd.c | target = DEVICE_NR(inode->i_rdev); |
inode | 161 | drivers/scsi/sd.c | sd_ioctl(inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0); |
inode | 900 | drivers/scsi/sd.c | struct inode inode; |
inode | 913 | drivers/scsi/sd.c | inode.i_rdev = full_dev; /* This is all we really need here */ |
inode | 914 | drivers/scsi/sd.c | retval = sd_ioctl(&inode, NULL, SCSI_IOCTL_TEST_UNIT_READY, 0); |
inode | 23 | drivers/scsi/sd_ioctl.c | int sd_ioctl(struct inode * inode, struct file * file, unsigned int cmd, unsigned long arg) |
inode | 25 | drivers/scsi/sd_ioctl.c | kdev_t dev = inode->i_rdev; |
inode | 57 | drivers/scsi/sd_ioctl.c | put_user(sd[MINOR(inode->i_rdev)].start_sect, &loc->start); |
inode | 64 | drivers/scsi/sd_ioctl.c | put_user(sd[MINOR(inode->i_rdev)].nr_sects, |
inode | 71 | drivers/scsi/sd_ioctl.c | if(!(inode->i_rdev)) return -EINVAL; |
inode | 73 | drivers/scsi/sd_ioctl.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 82 | drivers/scsi/sd_ioctl.c | put_user(read_ahead[MAJOR(inode->i_rdev)], (int *) arg); |
inode | 87 | drivers/scsi/sd_ioctl.c | if(!(inode->i_rdev)) return -EINVAL; |
inode | 88 | drivers/scsi/sd_ioctl.c | fsync_dev(inode->i_rdev); |
inode | 89 | drivers/scsi/sd_ioctl.c | invalidate_buffers(inode->i_rdev); |
inode | 66 | drivers/scsi/sg.c | static int sg_ioctl(struct inode * inode,struct file * file, |
inode | 70 | drivers/scsi/sg.c | int dev = MINOR(inode->i_rdev); |
inode | 88 | drivers/scsi/sg.c | static int sg_open(struct inode * inode, struct file * filp) |
inode | 90 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 150 | drivers/scsi/sg.c | static void sg_close(struct inode * inode, struct file * filp) |
inode | 152 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 199 | drivers/scsi/sg.c | static int sg_read(struct inode *inode,struct file *filp,char *buf,int count) |
inode | 201 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 295 | drivers/scsi/sg.c | static int sg_write(struct inode *inode,struct file *filp,const char *buf,int count) |
inode | 299 | drivers/scsi/sg.c | kdev_t devt = inode->i_rdev; |
inode | 459 | drivers/scsi/sg.c | static int sg_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 461 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 60 | drivers/scsi/sr.c | static int sr_open(struct inode *, struct file *); |
inode | 62 | drivers/scsi/sr.c | void sr_photocd(struct inode *); |
inode | 64 | drivers/scsi/sr.c | extern int sr_ioctl(struct inode *, struct file *, unsigned int, unsigned long); |
inode | 69 | drivers/scsi/sr.c | static void sr_release(struct inode * inode, struct file * file) |
inode | 71 | drivers/scsi/sr.c | sync_dev(inode->i_rdev); |
inode | 72 | drivers/scsi/sr.c | if(! --scsi_CDs[MINOR(inode->i_rdev)].device->access_count) |
inode | 74 | drivers/scsi/sr.c | sr_ioctl(inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0); |
inode | 75 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].auto_eject) |
inode | 76 | drivers/scsi/sr.c | sr_ioctl(inode, NULL, CDROMEJECT, 0); |
inode | 78 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count) |
inode | 79 | drivers/scsi/sr.c | (*scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count)--; |
inode | 112 | drivers/scsi/sr.c | struct inode inode; |
inode | 122 | drivers/scsi/sr.c | inode.i_rdev = full_dev; /* This is all we really need here */ |
inode | 123 | drivers/scsi/sr.c | retval = sr_ioctl(&inode, NULL, SCSI_IOCTL_TEST_UNIT_READY, 0); |
inode | 319 | drivers/scsi/sr.c | void sr_photocd(struct inode *inode) |
inode | 328 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].xa_flags & 0x02) { |
inode | 342 | drivers/scsi/sr.c | if (1 == scsi_CDs[MINOR(inode->i_rdev)].device->access_count) { |
inode | 343 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].mpcd_sector = 0; |
inode | 344 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags &= ~0x01; |
inode | 354 | drivers/scsi/sr.c | switch(scsi_CDs[MINOR(inode->i_rdev)].device->manufacturer) { |
inode | 366 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 402 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 410 | drivers/scsi/sr.c | if (!kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 438 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 463 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 470 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].needs_sector_size = 1; |
inode | 485 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 513 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].mpcd_sector = sector; |
inode | 515 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags |= 0x01; |
inode | 517 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags &= ~0x01; |
inode | 519 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags |= 0x02; |
inode | 523 | drivers/scsi/sr.c | static int sr_open(struct inode * inode, struct file * filp) |
inode | 525 | drivers/scsi/sr.c | if(MINOR(inode->i_rdev) >= sr_template.nr_dev || |
inode | 526 | drivers/scsi/sr.c | !scsi_CDs[MINOR(inode->i_rdev)].device) return -ENXIO; /* No such device */ |
inode | 531 | drivers/scsi/sr.c | check_disk_change(inode->i_rdev); |
inode | 533 | drivers/scsi/sr.c | if(!scsi_CDs[MINOR(inode->i_rdev)].device->access_count++) |
inode | 534 | drivers/scsi/sr.c | sr_ioctl(inode, NULL, SCSI_IOCTL_DOORLOCK, 0); |
inode | 535 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count) |
inode | 536 | drivers/scsi/sr.c | (*scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count)++; |
inode | 539 | drivers/scsi/sr.c | sr_photocd(inode); |
inode | 546 | drivers/scsi/sr.c | if(scsi_CDs[MINOR(inode->i_rdev)].needs_sector_size) |
inode | 547 | drivers/scsi/sr.c | get_sectorsize(MINOR(inode->i_rdev)); |
inode | 18 | drivers/scsi/sr_ioctl.c | extern void sr_photocd(struct inode *); |
inode | 91 | drivers/scsi/sr_ioctl.c | int sr_ioctl(struct inode * inode, struct file * file, unsigned int cmd, unsigned long arg) |
inode | 95 | drivers/scsi/sr_ioctl.c | kdev_t dev = inode->i_rdev; |
inode | 309 | drivers/scsi/sr_ioctl.c | check_disk_change (inode->i_rdev); |
inode | 310 | drivers/scsi/sr_ioctl.c | sr_ioctl (inode, NULL, SCSI_IOCTL_DOORLOCK, 0); |
inode | 311 | drivers/scsi/sr_ioctl.c | sr_photocd (inode); |
inode | 313 | drivers/scsi/sr_ioctl.c | if (scsi_CDs[MINOR(inode->i_rdev)].needs_sector_size) |
inode | 314 | drivers/scsi/sr_ioctl.c | get_sectorsize (MINOR(inode->i_rdev)); |
inode | 325 | drivers/scsi/sr_ioctl.c | sr_ioctl (inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0); |
inode | 559 | drivers/scsi/sr_ioctl.c | if(!(inode->i_rdev)) return -EINVAL; |
inode | 561 | drivers/scsi/sr_ioctl.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 110 | drivers/scsi/st.c | static int st_int_ioctl(struct inode * inode,struct file * file, |
inode | 407 | drivers/scsi/st.c | flush_buffer(struct inode * inode, struct file * filp, int seek_next) |
inode | 412 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 449 | drivers/scsi/st.c | result = st_int_ioctl(inode, filp, MTBSR, backspace); |
inode | 463 | drivers/scsi/st.c | scsi_tape_open(struct inode * inode, struct file * filp) |
inode | 472 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 473 | drivers/scsi/st.c | int mode = TAPE_MODE(inode->i_rdev); |
inode | 484 | drivers/scsi/st.c | STp->rew_at_close = (MINOR(inode->i_rdev) & 0x80) == 0; |
inode | 703 | drivers/scsi/st.c | st_int_ioctl(inode, filp, SET_DENS_AND_BLK, arg)) { |
inode | 716 | drivers/scsi/st.c | if (st_int_ioctl(inode, filp, MTSETDRVBUFFER, STp->default_drvbuffer)) |
inode | 732 | drivers/scsi/st.c | scsi_tape_close(struct inode * inode, struct file * filp) |
inode | 738 | drivers/scsi/st.c | kdev_t devt = inode->i_rdev; |
inode | 788 | drivers/scsi/st.c | flush_buffer(inode, filp, 0); |
inode | 794 | drivers/scsi/st.c | st_int_ioctl(inode, filp, MTREW, 1); |
inode | 797 | drivers/scsi/st.c | st_int_ioctl(inode, filp, MTUNLOCK, 0); |
inode | 815 | drivers/scsi/st.c | st_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 826 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 858 | drivers/scsi/st.c | !st_int_ioctl(inode, filp, MTLOCK, 0)) |
inode | 862 | drivers/scsi/st.c | retval = flush_buffer(inode, filp, 0); |
inode | 886 | drivers/scsi/st.c | st_int_ioctl(inode, filp, SET_DENS_AND_BLK, arg)) { |
inode | 1111 | drivers/scsi/st.c | st_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 1119 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 1144 | drivers/scsi/st.c | !st_int_ioctl(inode, filp, MTLOCK, 0)) |
inode | 1148 | drivers/scsi/st.c | transfer = flush_buffer(inode, filp, 0); |
inode | 1238 | drivers/scsi/st.c | st_int_ioctl(inode, filp, MTBSR, 1); |
inode | 1252 | drivers/scsi/st.c | if (st_int_ioctl(inode, filp, MTBSR, 1)) |
inode | 1397 | drivers/scsi/st.c | st_set_options(struct inode * inode, long options) |
inode | 1403 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 1617 | drivers/scsi/st.c | st_int_ioctl(struct inode * inode,struct file * file, |
inode | 1627 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 1832 | drivers/scsi/st.c | ioctl_result = st_int_ioctl(inode, file, MTFSF, 0x3fff); |
inode | 2002 | drivers/scsi/st.c | ioctl_result = st_int_ioctl(inode, file, MTFSF, 1); |
inode | 2004 | drivers/scsi/st.c | ioctl_result = st_int_ioctl(inode, file, MTBSF, 1); |
inode | 2029 | drivers/scsi/st.c | STp->rew_at_close = (MINOR(inode->i_rdev) & 0x80) == 0; |
inode | 2096 | drivers/scsi/st.c | st_ioctl(struct inode * inode,struct file * file, |
inode | 2106 | drivers/scsi/st.c | int dev = TAPE_NR(inode->i_rdev); |
inode | 2159 | drivers/scsi/st.c | i = flush_buffer(inode, file, mtc.mt_op == MTSEEK || |
inode | 2183 | drivers/scsi/st.c | if (st_int_ioctl(inode, file, MTLOCK, 0)) { |
inode | 2197 | drivers/scsi/st.c | st_int_ioctl(inode, file, MTUNLOCK, 0); /* Ignore result! */ |
inode | 2201 | drivers/scsi/st.c | return st_set_options(inode, mtc.mt_count); |
inode | 2205 | drivers/scsi/st.c | return st_int_ioctl(inode, file, mtc.mt_op, mtc.mt_count); |
inode | 2219 | drivers/scsi/st.c | i = flush_buffer(inode, file, FALSE); |
inode | 2278 | drivers/scsi/st.c | i = flush_buffer(inode, file, 0); |
inode | 562 | drivers/sound/dmasound.c | static int mixer_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 639 | drivers/sound/dmasound.c | static int sound_open(struct inode *inode, struct file *file); |
inode | 640 | drivers/sound/dmasound.c | static int sound_fsync(struct inode *inode, struct file *filp); |
inode | 641 | drivers/sound/dmasound.c | static void sound_release(struct inode *inode, struct file *file); |
inode | 642 | drivers/sound/dmasound.c | static int sound_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 644 | drivers/sound/dmasound.c | static int sound_read(struct inode *inode, struct file *file, char *buf, |
inode | 646 | drivers/sound/dmasound.c | static int sound_write(struct inode *inode, struct file *file, const char *buf, |
inode | 650 | drivers/sound/dmasound.c | static int sound_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 2452 | drivers/sound/dmasound.c | static int mixer_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 2921 | drivers/sound/dmasound.c | static int sound_open(struct inode *inode, struct file *file) |
inode | 2923 | drivers/sound/dmasound.c | int dev = MINOR(inode->i_rdev) & 0x0f; |
inode | 2952 | drivers/sound/dmasound.c | static int sound_fsync(struct inode *inode, struct file *filp) |
inode | 2954 | drivers/sound/dmasound.c | int dev = MINOR(inode->i_rdev) & 0x0f; |
inode | 2969 | drivers/sound/dmasound.c | static void sound_release(struct inode *inode, struct file *file) |
inode | 2971 | drivers/sound/dmasound.c | int dev = MINOR(inode->i_rdev); |
inode | 2986 | drivers/sound/dmasound.c | static int sound_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 2993 | drivers/sound/dmasound.c | static int sound_read(struct inode *inode, struct file *file, char *buf, |
inode | 2996 | drivers/sound/dmasound.c | int dev = MINOR(inode->i_rdev); |
inode | 3011 | drivers/sound/dmasound.c | static int sound_write(struct inode *inode, struct file *file, const char *buf, |
inode | 3014 | drivers/sound/dmasound.c | int dev = MINOR(inode->i_rdev); |
inode | 3052 | drivers/sound/dmasound.c | static int sound_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 3055 | drivers/sound/dmasound.c | int dev = MINOR(inode->i_rdev); |
inode | 3062 | drivers/sound/dmasound.c | return(mixer_ioctl(inode, file, cmd, arg)); |
inode | 3071 | drivers/sound/dmasound.c | return(sound_fsync(inode, file)); |
inode | 3077 | drivers/sound/dmasound.c | sound_fsync(inode, file); |
inode | 3080 | drivers/sound/dmasound.c | sound_fsync(inode, file); |
inode | 3083 | drivers/sound/dmasound.c | sound_fsync(inode, file); |
inode | 3086 | drivers/sound/dmasound.c | sound_fsync(inode, file); |
inode | 3116 | drivers/sound/dmasound.c | return(mixer_ioctl(inode, file, cmd, arg)); |
inode | 69 | drivers/sound/soundcard.c | sound_read (inode_handle * inode, file_handle * file, char *buf, int count) |
inode | 73 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 81 | drivers/sound/soundcard.c | sound_write (inode_handle * inode, file_handle * file, const char *buf, int count) |
inode | 85 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 93 | drivers/sound/soundcard.c | sound_lseek (inode_handle * inode, file_handle * file, off_t offset, int orig) |
inode | 99 | drivers/sound/soundcard.c | sound_open (inode_handle * inode, file_handle * file) |
inode | 110 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 140 | drivers/sound/soundcard.c | sound_release (inode_handle * inode, file_handle * file) |
inode | 144 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 155 | drivers/sound/soundcard.c | sound_ioctl (inode_handle * inode, file_handle * file, |
inode | 160 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 193 | drivers/sound/soundcard.c | sound_select (inode_handle * inode, file_handle * file, int sel_type, select_table_handle * wait) |
inode | 197 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 234 | drivers/sound/soundcard.c | sound_mmap (inode_handle * inode, file_handle * file, vm_area_handle * vma) |
inode | 240 | drivers/sound/soundcard.c | dev = MINOR (inode_get_rdev (inode)); |
inode | 311 | drivers/sound/soundcard.c | vma_set_inode (vma, inode); |
inode | 312 | drivers/sound/soundcard.c | inode_inc_count (inode); |
inode | 25 | fs/affs/dir.c | static int affs_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 67 | fs/affs/dir.c | static int affs_readdir(struct inode * inode, struct file * filp, |
inode | 79 | fs/affs/dir.c | inode->i_ino, filp->f_pos); |
inode | 82 | fs/affs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 87 | fs/affs/dir.c | if (filldir (dirent, ".", 1, filp->f_pos, inode->i_ino) < 0) |
inode | 90 | fs/affs/dir.c | i = affs_parent_ino (inode); |
inode | 104 | fs/affs/dir.c | if (!(dir_bh = affs_pread(inode, inode->i_ino, &dir_data))) |
inode | 109 | fs/affs/dir.c | i = affs_find_next_hash_entry (AFFS_I2BSIZE (inode), dir_data, |
inode | 121 | fs/affs/dir.c | if (!(fh_bh = affs_pread (inode, i, &fh_data))) { |
inode | 125 | fs/affs/dir.c | i = affs_get_fh_hash_link (AFFS_I2BSIZE (inode), fh_data); |
inode | 130 | fs/affs/dir.c | i = affs_find_next_hash_entry (AFFS_I2BSIZE (inode), |
inode | 138 | fs/affs/dir.c | reclen = affs_get_file_name (AFFS_I2BSIZE (inode), |
inode | 36 | fs/affs/file.c | int affs_file_read(struct inode *, struct file *, char *, int); |
inode | 73 | fs/affs/file.c | static int affs_smap(struct inode *inode, int block) |
inode | 83 | fs/affs/file.c | printk ("affs_smap: ino=%d block=%d\n", inode->i_ino, block); |
inode | 91 | fs/affs/file.c | key = inode->i_ino; |
inode | 93 | fs/affs/file.c | bh = affs_pread (inode, key, &fh_data); |
inode | 99 | fs/affs/file.c | key = affs_get_extension (AFFS_I2BSIZE (inode), fh_data); |
inode | 105 | fs/affs/file.c | key = affs_get_key_entry (AFFS_I2BSIZE (inode), fh_data, |
inode | 121 | fs/affs/file.c | int affs_file_read(struct inode * inode, struct file * filp, |
inode | 129 | fs/affs/file.c | if (!inode) { |
inode | 133 | fs/affs/file.c | if (!(S_ISREG(inode->i_mode))) { |
inode | 135 | fs/affs/file.c | printk("affs_file_read: mode = %07o\n",inode->i_mode); |
inode | 139 | fs/affs/file.c | if (filp->f_pos >= inode->i_size || count <= 0) |
inode | 144 | fs/affs/file.c | left = MIN (inode->i_size - filp->f_pos, |
inode | 148 | fs/affs/file.c | sector = affs_smap (inode, filp->f_pos >> AFFS_BLOCK_BITS); |
inode | 152 | fs/affs/file.c | bh = affs_pread (inode, sector, &data); |
inode | 60 | fs/affs/inode.c | int affs_parent_ino(struct inode *dir) |
inode | 272 | fs/affs/inode.c | void affs_read_inode(struct inode * inode) |
inode | 287 | fs/affs/inode.c | inode->i_nlink = 1; /* at least */ |
inode | 290 | fs/affs/inode.c | block = inode->i_ino; |
inode | 291 | fs/affs/inode.c | if (!(bh=affs_pread (inode, block, &fh_data))) { |
inode | 298 | fs/affs/inode.c | AFFS_I2BSIZE (inode)); |
inode | 301 | fs/affs/inode.c | if (block == inode->i_sb->u.affs_sb.s_root_block) { |
inode | 302 | fs/affs/inode.c | inode->u.affs_i.i_protect = 0; |
inode | 303 | fs/affs/inode.c | inode->u.affs_i.i_parent = block; |
inode | 305 | fs/affs/inode.c | inode->i_mode = S_IRWXUGO | S_IFDIR | S_ISVTX ; /* drwxrwxrwt */ |
inode | 306 | fs/affs/inode.c | inode->i_nlink = 2; /* at least ..... */ |
inode | 308 | fs/affs/inode.c | inode->i_size = 0; /* some different idea ? */ |
inode | 310 | fs/affs/inode.c | inode->i_uid = 0; |
inode | 311 | fs/affs/inode.c | inode->i_gid = 0; |
inode | 315 | fs/affs/inode.c | inode->u.affs_i.i_protect = file_end->protect; |
inode | 316 | fs/affs/inode.c | inode->u.affs_i.i_parent = swap_long (file_end->parent); |
inode | 318 | fs/affs/inode.c | inode->i_mode = 0; |
inode | 320 | fs/affs/inode.c | if ((prot_table[i][0] & inode->u.affs_i.i_protect) == prot_table[i][1]) |
inode | 321 | fs/affs/inode.c | inode->i_mode |= 1<<i; |
inode | 324 | fs/affs/inode.c | inode->i_mode |= ((inode->i_mode & 0444)>>2) | S_IFDIR; |
inode | 326 | fs/affs/inode.c | inode->i_nlink++; /* There are always at least 2. It is |
inode | 328 | fs/affs/inode.c | inode->i_size = 0; |
inode | 331 | fs/affs/inode.c | inode->i_mode |= S_IFLNK; |
inode | 332 | fs/affs/inode.c | inode->i_size = 0; |
inode | 342 | fs/affs/inode.c | inode->i_ino = link_end->original; |
inode | 343 | fs/affs/inode.c | inode->i_nlink += 2; /* It's hard to say what's correct */ |
inode | 351 | fs/affs/inode.c | inode->i_mode |= S_IFREG; |
inode | 352 | fs/affs/inode.c | inode->i_size = swap_long (file_end->byte_size); |
inode | 356 | fs/affs/inode.c | inode->i_uid = 0; /* root uid */ |
inode | 359 | fs/affs/inode.c | inode->i_uid = -1; /* unknown uid */ |
inode | 368 | fs/affs/inode.c | mode = (inode->i_mode >> 6) & 7; |
inode | 369 | fs/affs/inode.c | inode->i_mode |= (mode << 3) | (mode); |
inode | 371 | fs/affs/inode.c | inode->i_uid = file_end->uid; |
inode | 373 | fs/affs/inode.c | inode->i_gid = 0; /* root gid */ |
inode | 375 | fs/affs/inode.c | inode->i_gid = -1; /* unknown gid */ |
inode | 377 | fs/affs/inode.c | inode->i_gid = file_end->gid; |
inode | 383 | fs/affs/inode.c | printk ("AFFS: read inode %d: size=%d\n", block, inode->i_size); |
inode | 385 | fs/affs/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime |
inode | 393 | fs/affs/inode.c | inode->i_op = NULL; |
inode | 394 | fs/affs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 395 | fs/affs/inode.c | inode->i_op = &affs_file_inode_operations; |
inode | 396 | fs/affs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 397 | fs/affs/inode.c | inode->i_op = &affs_dir_inode_operations; |
inode | 398 | fs/affs/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 399 | fs/affs/inode.c | inode->i_op = &affs_symlink_inode_operations; |
inode | 72 | fs/affs/namei.c | static struct buffer_head *affs_find_entry(struct inode *dir, |
inode | 118 | fs/affs/namei.c | int affs_lookup(struct inode * dir,const char * name, int len, |
inode | 119 | fs/affs/namei.c | struct inode ** result) |
inode | 26 | fs/affs/symlink.c | static int affs_readlink(struct inode *, char *, int); |
inode | 27 | fs/affs/symlink.c | static int affs_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 50 | fs/affs/symlink.c | static int affs_follow_link(struct inode * dir, struct inode * inode, |
inode | 51 | fs/affs/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 62 | fs/affs/symlink.c | if (!inode) { |
inode | 67 | fs/affs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 69 | fs/affs/symlink.c | *res_inode = inode; |
inode | 74 | fs/affs/symlink.c | iput(inode); |
inode | 78 | fs/affs/symlink.c | if (!(bh = affs_pread(inode,inode->i_ino,(void **)&sy_data))) { |
inode | 79 | fs/affs/symlink.c | printk("affs: unable to read block %ld",inode->i_ino); |
inode | 84 | fs/affs/symlink.c | iput(inode); |
inode | 142 | fs/affs/symlink.c | static int affs_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 150 | fs/affs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 151 | fs/affs/symlink.c | iput(inode); |
inode | 158 | fs/affs/symlink.c | if (!(bh = affs_pread(inode,inode->i_ino,(void **)&sy_data))) { |
inode | 159 | fs/affs/symlink.c | printk("affs: unable to read block %ld\n",inode->i_ino); |
inode | 163 | fs/affs/symlink.c | iput(inode); |
inode | 166 | fs/affs/symlink.c | if (inode->i_sb->u.affs_sb.s_options.conv_links != 0) |
inode | 60 | fs/binfmt_aout.c | while (file.f_op->write(inode,&file,(char *)(addr),(nr)) != (nr)) goto close_coredump |
inode | 64 | fs/binfmt_aout.c | if (file.f_op->lseek(inode,&file,(offset),0) != (offset)) \ |
inode | 81 | fs/binfmt_aout.c | struct inode * inode = NULL; |
inode | 109 | fs/binfmt_aout.c | if (open_namei(corefile,O_CREAT | 2 | O_TRUNC,0600,&inode,NULL)) { |
inode | 110 | fs/binfmt_aout.c | inode = NULL; |
inode | 113 | fs/binfmt_aout.c | if (!S_ISREG(inode->i_mode)) |
inode | 115 | fs/binfmt_aout.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 117 | fs/binfmt_aout.c | if (get_write_access(inode)) |
inode | 122 | fs/binfmt_aout.c | file.f_inode = inode; |
inode | 125 | fs/binfmt_aout.c | file.f_op = inode->i_op->default_file_ops; |
inode | 127 | fs/binfmt_aout.c | if (file.f_op->open(inode,&file)) |
inode | 180 | fs/binfmt_aout.c | file.f_op->release(inode,&file); |
inode | 182 | fs/binfmt_aout.c | put_write_access(inode); |
inode | 185 | fs/binfmt_aout.c | iput(inode); |
inode | 271 | fs/binfmt_aout.c | bprm->inode->i_size < ex.a_text+ex.a_data+N_SYMSIZE(ex)+N_TXTOFF(ex)) { |
inode | 285 | fs/binfmt_aout.c | (fd_offset < bprm->inode->i_sb->s_blocksize)) { |
inode | 322 | fs/binfmt_aout.c | read_exec(bprm->inode, fd_offset, (char *) N_TXTADDR(ex), |
inode | 328 | fs/binfmt_aout.c | read_exec(bprm->inode, 32, (char *) 0, ex.a_text+ex.a_data, 0); |
inode | 334 | fs/binfmt_aout.c | fd = open_inode(bprm->inode, O_RDONLY); |
inode | 344 | fs/binfmt_aout.c | read_exec(bprm->inode, fd_offset, |
inode | 413 | fs/binfmt_aout.c | struct inode * inode; |
inode | 420 | fs/binfmt_aout.c | inode = file->f_inode; |
inode | 427 | fs/binfmt_aout.c | if ((error = file->f_op->lseek(inode, file, 0, 0)) != 0) |
inode | 433 | fs/binfmt_aout.c | error = file->f_op->read(inode, file, (char *) &ex, sizeof(ex)); |
inode | 441 | fs/binfmt_aout.c | inode->i_size < ex.a_text+ex.a_data+N_SYMSIZE(ex)+N_TXTOFF(ex)) { |
inode | 445 | fs/binfmt_aout.c | (N_TXTOFF(ex) < inode->i_sb->s_blocksize)) { |
inode | 156 | fs/binfmt_elf.c | struct inode * interpreter_inode, unsigned int *interp_load_addr) |
inode | 285 | fs/binfmt_elf.c | struct inode * interpreter_inode) |
inode | 339 | fs/binfmt_elf.c | struct inode *interpreter_inode; |
inode | 372 | fs/binfmt_elf.c | (!bprm->inode->i_op || !bprm->inode->i_op->default_file_ops || |
inode | 373 | fs/binfmt_elf.c | !bprm->inode->i_op->default_file_ops->mmap)){ |
inode | 385 | fs/binfmt_elf.c | retval = read_exec(bprm->inode, elf_ex.e_phoff, (char *) elf_phdata, |
inode | 397 | fs/binfmt_elf.c | elf_exec_fileno = open_inode(bprm->inode, O_RDONLY); |
inode | 435 | fs/binfmt_elf.c | retval = read_exec(bprm->inode,elf_ppnt->p_offset,elf_interpreter, |
inode | 625 | fs/binfmt_elf.c | current->executable = bprm->inode; |
inode | 626 | fs/binfmt_elf.c | bprm->inode->i_count++; |
inode | 709 | fs/binfmt_elf.c | struct inode * inode; |
inode | 719 | fs/binfmt_elf.c | inode = file->f_inode; |
inode | 727 | fs/binfmt_elf.c | if ((error = file->f_op->lseek(inode, file, 0, 0)) != 0) |
inode | 733 | fs/binfmt_elf.c | error = file->f_op->read(inode, file, (char *) &elf_ex, sizeof(elf_ex)); |
inode | 745 | fs/binfmt_elf.c | (!inode->i_op || !inode->i_op->default_file_ops->mmap)) |
inode | 758 | fs/binfmt_elf.c | retval = read_exec(inode, elf_ex.e_phoff, (char *) elf_phdata, |
inode | 939 | fs/binfmt_elf.c | struct inode *inode; |
inode | 1012 | fs/binfmt_elf.c | if (open_namei(corefile,O_CREAT | 2 | O_TRUNC,0600,&inode,NULL)) { |
inode | 1013 | fs/binfmt_elf.c | inode = NULL; |
inode | 1016 | fs/binfmt_elf.c | if (!S_ISREG(inode->i_mode)) |
inode | 1018 | fs/binfmt_elf.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 1023 | fs/binfmt_elf.c | file.f_inode = inode; |
inode | 1026 | fs/binfmt_elf.c | file.f_op = inode->i_op->default_file_ops; |
inode | 1028 | fs/binfmt_elf.c | if (file.f_op->open(inode,&file)) |
inode | 1206 | fs/binfmt_elf.c | file.f_op->release(inode,&file); |
inode | 1210 | fs/binfmt_elf.c | iput(inode); |
inode | 26 | fs/binfmt_script.c | iput(bprm->inode); |
inode | 79 | fs/binfmt_script.c | retval = open_namei(interp, 0, 0, &bprm->inode, NULL); |
inode | 23 | fs/block_dev.c | int block_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 40 | fs/block_dev.c | dev = inode->i_rdev; |
inode | 41 | fs/block_dev.c | if ( is_read_only( inode->i_rdev )) |
inode | 160 | fs/block_dev.c | int block_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 179 | fs/block_dev.c | dev = inode->i_rdev; |
inode | 316 | fs/block_dev.c | int block_fsync(struct inode *inode, struct file *filp) |
inode | 318 | fs/block_dev.c | return fsync_dev (inode->i_rdev); |
inode | 255 | fs/buffer.c | int file_fsync (struct inode *inode, struct file *filp) |
inode | 257 | fs/buffer.c | return fsync_dev(inode->i_dev); |
inode | 263 | fs/buffer.c | struct inode * inode; |
inode | 265 | fs/buffer.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 269 | fs/buffer.c | if (file->f_op->fsync(inode,file)) |
inode | 277 | fs/buffer.c | struct inode * inode; |
inode | 279 | fs/buffer.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 284 | fs/buffer.c | if (file->f_op->fsync(inode,file)) |
inode | 1290 | fs/buffer.c | int generic_readpage(struct inode * inode, struct page * page) |
inode | 1301 | fs/buffer.c | i = PAGE_SIZE >> inode->i_sb->s_blocksize_bits; |
inode | 1302 | fs/buffer.c | block = page->offset >> inode->i_sb->s_blocksize_bits; |
inode | 1305 | fs/buffer.c | *p = inode->i_op->bmap(inode, block); |
inode | 1312 | fs/buffer.c | brw_page(READ, address, inode->i_dev, nr, inode->i_sb->s_blocksize, 1); |
inode | 144 | fs/dcache.c | static inline struct dir_cache_entry * find_entry(struct inode * dir, const char * name, int len, struct hash_list * hash) |
inode | 183 | fs/dcache.c | int dcache_lookup(struct inode * dir, const char * name, int len, unsigned long * ino) |
inode | 199 | fs/dcache.c | void dcache_add(struct inode * dir, const char * name, int len, unsigned long ino) |
inode | 227 | fs/devices.c | int blkdev_open(struct inode * inode, struct file * filp) |
inode | 230 | fs/devices.c | filp->f_op = get_blkfops(MAJOR(inode->i_rdev)); |
inode | 234 | fs/devices.c | ret = filp->f_op->open(inode,filp); |
inode | 239 | fs/devices.c | void blkdev_release(struct inode * inode) |
inode | 241 | fs/devices.c | struct file_operations *fops = get_blkfops(MAJOR(inode->i_rdev)); |
inode | 243 | fs/devices.c | fops->release(inode,NULL); |
inode | 287 | fs/devices.c | int chrdev_open(struct inode * inode, struct file * filp) |
inode | 291 | fs/devices.c | filp->f_op = get_chrfops(MAJOR(inode->i_rdev), MINOR(inode->i_rdev)); |
inode | 295 | fs/devices.c | ret = filp->f_op->open(inode,filp); |
inode | 680 | fs/dquot.c | void dquot_initialize(struct inode *inode, short type) |
inode | 686 | fs/dquot.c | if (S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || S_ISLNK(inode->i_mode)) { |
inode | 690 | fs/dquot.c | if (!has_quota_enabled(inode->i_dev, cnt)) |
inode | 692 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) { |
inode | 695 | fs/dquot.c | id = inode->i_uid; |
inode | 698 | fs/dquot.c | id = inode->i_gid; |
inode | 702 | fs/dquot.c | tmp = dqget(inode->i_dev, id, cnt); |
inode | 706 | fs/dquot.c | if (inode->i_dquot[cnt] != NODQUOT) { |
inode | 710 | fs/dquot.c | inode->i_dquot[cnt] = tmp; |
inode | 711 | fs/dquot.c | inode->i_flags |= S_WRITE; |
inode | 717 | fs/dquot.c | void dquot_drop(struct inode *inode) |
inode | 723 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 728 | fs/dquot.c | tmp = inode->i_dquot[cnt]; |
inode | 729 | fs/dquot.c | inode->i_dquot[cnt] = NODQUOT; |
inode | 732 | fs/dquot.c | inode->i_flags &= ~S_WRITE; |
inode | 762 | fs/dquot.c | int dquot_alloc_block(const struct inode *inode, unsigned long number) |
inode | 767 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 769 | fs/dquot.c | if (check_bdq(inode->i_dquot[cnt], cnt, number)) |
inode | 773 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 775 | fs/dquot.c | dquot_incr_blocks(inode->i_dquot[cnt], number); |
inode | 780 | fs/dquot.c | int dquot_alloc_inode(const struct inode *inode, unsigned long number) |
inode | 785 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 787 | fs/dquot.c | if (check_idq(inode->i_dquot[cnt], cnt, number)) |
inode | 791 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 793 | fs/dquot.c | dquot_incr_inodes(inode->i_dquot[cnt], number); |
inode | 798 | fs/dquot.c | void dquot_free_block(const struct inode *inode, unsigned long number) |
inode | 803 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 805 | fs/dquot.c | dquot_decr_blocks(inode->i_dquot[cnt], number); |
inode | 809 | fs/dquot.c | void dquot_free_inode(const struct inode *inode, unsigned long number) |
inode | 814 | fs/dquot.c | if (inode->i_dquot[cnt] == NODQUOT) |
inode | 816 | fs/dquot.c | dquot_decr_inodes(inode->i_dquot[cnt], number); |
inode | 823 | fs/dquot.c | int dquot_transfer(struct inode *inode, struct iattr *iattr, char direction) |
inode | 833 | fs/dquot.c | if (inode->i_blksize == 0) |
inode | 834 | fs/dquot.c | blocks = isize_to_blocks(inode->i_size, BLOCK_SIZE); |
inode | 836 | fs/dquot.c | blocks = (inode->i_blocks / 2); |
inode | 846 | fs/dquot.c | if (!has_quota_enabled(inode->i_dev, cnt)) |
inode | 851 | fs/dquot.c | if (inode->i_uid == iattr->ia_uid) |
inode | 853 | fs/dquot.c | transfer_from[cnt] = dqget(inode->i_dev, (direction) ? iattr->ia_uid : inode->i_uid, cnt); |
inode | 854 | fs/dquot.c | transfer_to[cnt] = dqget(inode->i_dev, (direction) ? inode->i_uid : iattr->ia_uid, cnt); |
inode | 857 | fs/dquot.c | if (inode->i_gid == iattr->ia_gid) |
inode | 859 | fs/dquot.c | transfer_from[cnt] = dqget(inode->i_dev, (direction) ? iattr->ia_gid : inode->i_gid, cnt); |
inode | 860 | fs/dquot.c | transfer_to[cnt] = dqget(inode->i_dev, (direction) ? inode->i_gid : iattr->ia_gid, cnt); |
inode | 893 | fs/dquot.c | if (inode->i_dquot[cnt] != NODQUOT) { |
inode | 895 | fs/dquot.c | dqput(inode->i_dquot[cnt]); |
inode | 896 | fs/dquot.c | inode->i_dquot[cnt] = transfer_to[cnt]; |
inode | 954 | fs/dquot.c | struct inode *inode; |
inode | 965 | fs/dquot.c | error = open_namei(tmp, O_RDWR, 0600, &inode, 0); |
inode | 969 | fs/dquot.c | if (!S_ISREG(inode->i_mode)) { |
inode | 970 | fs/dquot.c | iput(inode); |
inode | 976 | fs/dquot.c | filp->f_inode = inode; |
inode | 979 | fs/dquot.c | filp->f_op = inode->i_op->default_file_ops; |
inode | 981 | fs/dquot.c | if ((error = get_write_access(inode)) == 0) { |
inode | 983 | fs/dquot.c | error = filp->f_op->open(inode, filp); |
inode | 994 | fs/dquot.c | put_write_access(inode); |
inode | 1001 | fs/dquot.c | iput(inode); |
inode | 1014 | fs/dquot.c | struct inode *ino; |
inode | 111 | fs/exec.c | int open_inode(struct inode * inode, int mode) |
inode | 116 | fs/exec.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 135 | fs/exec.c | f->f_inode = inode; |
inode | 138 | fs/exec.c | f->f_op = inode->i_op->default_file_ops; |
inode | 140 | fs/exec.c | error = f->f_op->open(inode,f); |
inode | 147 | fs/exec.c | inode->i_count++; |
inode | 324 | fs/exec.c | int read_exec(struct inode *inode, unsigned long offset, |
inode | 330 | fs/exec.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 335 | fs/exec.c | file.f_inode = inode; |
inode | 338 | fs/exec.c | file.f_op = inode->i_op->default_file_ops; |
inode | 340 | fs/exec.c | if (file.f_op->open(inode,&file)) |
inode | 345 | fs/exec.c | if (file.f_op->lseek(inode,&file,offset,0) != offset) |
inode | 352 | fs/exec.c | result = file.f_op->read(inode, &file, addr, count); |
inode | 358 | fs/exec.c | result = file.f_op->read(inode, &file, addr, count); |
inode | 362 | fs/exec.c | file.f_op->release(inode,&file); |
inode | 426 | fs/exec.c | permission(bprm->inode,MAY_READ)) |
inode | 450 | fs/exec.c | mode = bprm->inode->i_mode; |
inode | 455 | fs/exec.c | if (IS_NOEXEC(bprm->inode)) /* FS mustn't be mounted noexec */ |
inode | 457 | fs/exec.c | if (!bprm->inode->i_sb) |
inode | 459 | fs/exec.c | if ((retval = permission(bprm->inode, MAY_EXEC)) != 0) |
inode | 462 | fs/exec.c | if (bprm->inode->i_writecount > 0) |
inode | 471 | fs/exec.c | bprm->e_uid = bprm->inode->i_uid; |
inode | 483 | fs/exec.c | bprm->e_gid = bprm->inode->i_gid; |
inode | 492 | fs/exec.c | if (IS_NOSUID(bprm->inode) |
inode | 503 | fs/exec.c | return read_exec(bprm->inode,0,bprm->buf,128,1); |
inode | 538 | fs/exec.c | iput(bprm->inode); |
inode | 544 | fs/exec.c | retval = open_namei(dynloader[0], 0, 0, &bprm->inode, NULL); |
inode | 564 | fs/exec.c | iput(bprm->inode); |
inode | 606 | fs/exec.c | retval = open_namei(filename, 0, 0, &bprm.inode, NULL); |
inode | 638 | fs/exec.c | iput(bprm.inode); |
inode | 23 | fs/ext/dir.c | static int ext_dir_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 28 | fs/ext/dir.c | static int ext_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 66 | fs/ext/dir.c | static int ext_readdir(struct inode * inode, struct file * filp, |
inode | 75 | fs/ext/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 80 | fs/ext/dir.c | while (!error && filp->f_pos < inode->i_size) { |
inode | 82 | fs/ext/dir.c | bh = ext_bread(inode,(filp->f_pos)>>BLOCK_SIZE_BITS,0); |
inode | 95 | fs/ext/dir.c | while (offset < 1024 && filp->f_pos < inode->i_size) { |
inode | 102 | fs/ext/dir.c | kdevname(inode->i_dev), inode->i_ino, |
inode | 105 | fs/ext/dir.c | if (filp->f_pos > inode->i_size) |
inode | 106 | fs/ext/dir.c | filp->f_pos = inode->i_size; |
inode | 109 | fs/ext/dir.c | if (de->inode) { |
inode | 110 | fs/ext/dir.c | error = filldir(dirent, de->name, de->name_len, filp->f_pos, de->inode); |
inode | 35 | fs/ext/file.c | static int ext_file_read(struct inode *, struct file *, char *, int); |
inode | 36 | fs/ext/file.c | static int ext_file_write(struct inode *, struct file *, const char *, int); |
inode | 75 | fs/ext/file.c | static int ext_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 85 | fs/ext/file.c | if (!inode) { |
inode | 89 | fs/ext/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 90 | fs/ext/file.c | printk("ext_file_read: mode = %07o\n",inode->i_mode); |
inode | 94 | fs/ext/file.c | size = inode->i_size; |
inode | 110 | fs/ext/file.c | if(blocks < read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9)) |
inode | 111 | fs/ext/file.c | blocks = read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9); |
inode | 131 | fs/ext/file.c | *bhb = ext_getblk(inode, block++, 0); |
inode | 193 | fs/ext/file.c | if (!IS_RDONLY(inode)) { |
inode | 194 | fs/ext/file.c | inode->i_atime = CURRENT_TIME; |
inode | 195 | fs/ext/file.c | inode->i_dirt = 1; |
inode | 200 | fs/ext/file.c | static int ext_file_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 207 | fs/ext/file.c | if (!inode) { |
inode | 211 | fs/ext/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 212 | fs/ext/file.c | printk("ext_file_write: mode = %07o\n",inode->i_mode); |
inode | 220 | fs/ext/file.c | pos = inode->i_size; |
inode | 225 | fs/ext/file.c | bh = ext_getblk(inode,pos/BLOCK_SIZE,1); |
inode | 246 | fs/ext/file.c | update_vm_cache(inode, pos, p, c); |
inode | 248 | fs/ext/file.c | if (pos > inode->i_size) { |
inode | 249 | fs/ext/file.c | inode->i_size = pos; |
inode | 250 | fs/ext/file.c | inode->i_dirt = 1; |
inode | 258 | fs/ext/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 260 | fs/ext/file.c | inode->i_dirt = 1; |
inode | 175 | fs/ext/freelists.c | void ext_free_inode(struct inode * inode) |
inode | 184 | fs/ext/freelists.c | if (!inode) |
inode | 186 | fs/ext/freelists.c | if (!inode->i_dev) { |
inode | 190 | fs/ext/freelists.c | if (inode->i_count != 1) { |
inode | 191 | fs/ext/freelists.c | printk("free_inode: inode has count=%d\n",inode->i_count); |
inode | 194 | fs/ext/freelists.c | if (inode->i_nlink) { |
inode | 195 | fs/ext/freelists.c | printk("free_inode: inode has nlink=%d\n",inode->i_nlink); |
inode | 198 | fs/ext/freelists.c | if (!inode->i_sb) { |
inode | 202 | fs/ext/freelists.c | sb = inode->i_sb; |
inode | 203 | fs/ext/freelists.c | ino = inode->i_ino; |
inode | 204 | fs/ext/freelists.c | dev = inode->i_dev; |
inode | 205 | fs/ext/freelists.c | clear_inode(inode); |
inode | 239 | fs/ext/freelists.c | struct inode * ext_new_inode(const struct inode * dir) |
inode | 242 | fs/ext/freelists.c | struct inode * inode; |
inode | 247 | fs/ext/freelists.c | if (!dir || !(inode=get_empty_inode())) |
inode | 250 | fs/ext/freelists.c | inode->i_sb = sb; |
inode | 251 | fs/ext/freelists.c | inode->i_flags = sb->s_flags; |
inode | 282 | fs/ext/freelists.c | inode->i_count = 1; |
inode | 283 | fs/ext/freelists.c | inode->i_nlink = 1; |
inode | 284 | fs/ext/freelists.c | inode->i_dev = sb->s_dev; |
inode | 285 | fs/ext/freelists.c | inode->i_uid = current->fsuid; |
inode | 286 | fs/ext/freelists.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 287 | fs/ext/freelists.c | inode->i_dirt = 1; |
inode | 288 | fs/ext/freelists.c | inode->i_ino = j; |
inode | 289 | fs/ext/freelists.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 290 | fs/ext/freelists.c | inode->i_op = NULL; |
inode | 291 | fs/ext/freelists.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 292 | fs/ext/freelists.c | insert_inode_hash(inode); |
inode | 294 | fs/ext/freelists.c | printk("ext_new_inode : allocating inode %d\n", inode->i_ino); |
inode | 297 | fs/ext/freelists.c | return inode; |
inode | 30 | fs/ext/fsync.c | static int sync_block (struct inode * inode, unsigned long * block, int wait) |
inode | 38 | fs/ext/fsync.c | bh = get_hash_table(inode->i_dev, *block, blocksize); |
inode | 59 | fs/ext/fsync.c | static int sync_iblock (struct inode * inode, unsigned long * iblock, |
inode | 68 | fs/ext/fsync.c | rc = sync_block (inode, iblock, wait); |
inode | 71 | fs/ext/fsync.c | *bh = bread(inode->i_dev, tmp, blocksize); |
inode | 83 | fs/ext/fsync.c | static int sync_direct(struct inode *inode, int wait) |
inode | 89 | fs/ext/fsync.c | rc = sync_block (inode, inode->u.ext_i.i_data + i, wait); |
inode | 98 | fs/ext/fsync.c | static int sync_indirect(struct inode *inode, unsigned long *iblock, int wait) |
inode | 104 | fs/ext/fsync.c | rc = sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 109 | fs/ext/fsync.c | rc = sync_block (inode, |
inode | 121 | fs/ext/fsync.c | static int sync_dindirect(struct inode *inode, unsigned long *diblock, |
inode | 128 | fs/ext/fsync.c | rc = sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 133 | fs/ext/fsync.c | rc = sync_indirect (inode, |
inode | 145 | fs/ext/fsync.c | static int sync_tindirect(struct inode *inode, unsigned long *tiblock, |
inode | 152 | fs/ext/fsync.c | rc = sync_iblock (inode, tiblock, &tind_bh, wait); |
inode | 157 | fs/ext/fsync.c | rc = sync_dindirect (inode, |
inode | 169 | fs/ext/fsync.c | int ext_sync_file(struct inode * inode, struct file *file) |
inode | 173 | fs/ext/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 174 | fs/ext/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 178 | fs/ext/fsync.c | err |= sync_direct(inode, wait); |
inode | 179 | fs/ext/fsync.c | err |= sync_indirect(inode, inode->u.ext_i.i_data+9, wait); |
inode | 180 | fs/ext/fsync.c | err |= sync_dindirect(inode, inode->u.ext_i.i_data+10, wait); |
inode | 181 | fs/ext/fsync.c | err |= sync_tindirect(inode, inode->u.ext_i.i_data+11, wait); |
inode | 183 | fs/ext/fsync.c | err |= ext_sync_inode (inode); |
inode | 26 | fs/ext/inode.c | void ext_put_inode(struct inode *inode) |
inode | 28 | fs/ext/inode.c | if (inode->i_nlink) |
inode | 30 | fs/ext/inode.c | inode->i_size = 0; |
inode | 31 | fs/ext/inode.c | ext_truncate(inode); |
inode | 32 | fs/ext/inode.c | ext_free_inode(inode); |
inode | 172 | fs/ext/inode.c | #define inode_bmap(inode,nr) ((inode)->u.ext_i.i_data[(nr)]) |
inode | 185 | fs/ext/inode.c | int ext_bmap(struct inode * inode,int block) |
inode | 198 | fs/ext/inode.c | return inode_bmap(inode,block); |
inode | 201 | fs/ext/inode.c | i = inode_bmap(inode,9); |
inode | 204 | fs/ext/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block); |
inode | 208 | fs/ext/inode.c | i = inode_bmap(inode,10); |
inode | 211 | fs/ext/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block>>8); |
inode | 214 | fs/ext/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 255); |
inode | 217 | fs/ext/inode.c | i = inode_bmap(inode,11); |
inode | 220 | fs/ext/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block>>16); |
inode | 223 | fs/ext/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),(block>>8) & 255); |
inode | 226 | fs/ext/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 255); |
inode | 229 | fs/ext/inode.c | static struct buffer_head * inode_getblk(struct inode * inode, int nr, int create) |
inode | 235 | fs/ext/inode.c | p = inode->u.ext_i.i_data + nr; |
inode | 239 | fs/ext/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 247 | fs/ext/inode.c | tmp = ext_new_block(inode->i_sb); |
inode | 250 | fs/ext/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 252 | fs/ext/inode.c | ext_free_block(inode->i_sb,tmp); |
inode | 257 | fs/ext/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 258 | fs/ext/inode.c | inode->i_dirt = 1; |
inode | 262 | fs/ext/inode.c | static struct buffer_head * block_getblk(struct inode * inode, |
inode | 295 | fs/ext/inode.c | tmp = ext_new_block(inode->i_sb); |
inode | 302 | fs/ext/inode.c | ext_free_block(inode->i_sb,tmp); |
inode | 312 | fs/ext/inode.c | struct buffer_head * ext_getblk(struct inode * inode, int block, int create) |
inode | 325 | fs/ext/inode.c | return inode_getblk(inode,block,create); |
inode | 328 | fs/ext/inode.c | bh = inode_getblk(inode,9,create); |
inode | 329 | fs/ext/inode.c | return block_getblk(inode,bh,block,create); |
inode | 333 | fs/ext/inode.c | bh = inode_getblk(inode,10,create); |
inode | 334 | fs/ext/inode.c | bh = block_getblk(inode,bh,block>>8,create); |
inode | 335 | fs/ext/inode.c | return block_getblk(inode,bh,block & 255,create); |
inode | 338 | fs/ext/inode.c | bh = inode_getblk(inode,11,create); |
inode | 339 | fs/ext/inode.c | bh = block_getblk(inode,bh,block>>16,create); |
inode | 340 | fs/ext/inode.c | bh = block_getblk(inode,bh,(block>>8) & 255,create); |
inode | 341 | fs/ext/inode.c | return block_getblk(inode,bh,block & 255,create); |
inode | 344 | fs/ext/inode.c | struct buffer_head * ext_bread(struct inode * inode, int block, int create) |
inode | 348 | fs/ext/inode.c | bh = ext_getblk(inode,block,create); |
inode | 359 | fs/ext/inode.c | void ext_read_inode(struct inode * inode) |
inode | 365 | fs/ext/inode.c | block = 2 + (inode->i_ino-1)/EXT_INODES_PER_BLOCK; |
inode | 366 | fs/ext/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) |
inode | 369 | fs/ext/inode.c | (inode->i_ino-1)%EXT_INODES_PER_BLOCK; |
inode | 370 | fs/ext/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 371 | fs/ext/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 372 | fs/ext/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 373 | fs/ext/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 374 | fs/ext/inode.c | inode->i_size = raw_inode->i_size; |
inode | 375 | fs/ext/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = raw_inode->i_time; |
inode | 376 | fs/ext/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 377 | fs/ext/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 378 | fs/ext/inode.c | inode->i_rdev = to_kdev_t(raw_inode->i_zone[0]); |
inode | 380 | fs/ext/inode.c | inode->u.ext_i.i_data[block] = raw_inode->i_zone[block]; |
inode | 382 | fs/ext/inode.c | inode->i_op = NULL; |
inode | 383 | fs/ext/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 384 | fs/ext/inode.c | inode->i_op = &ext_file_inode_operations; |
inode | 385 | fs/ext/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 386 | fs/ext/inode.c | inode->i_op = &ext_dir_inode_operations; |
inode | 387 | fs/ext/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 388 | fs/ext/inode.c | inode->i_op = &ext_symlink_inode_operations; |
inode | 389 | fs/ext/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 390 | fs/ext/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 391 | fs/ext/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 392 | fs/ext/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 393 | fs/ext/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 394 | fs/ext/inode.c | init_fifo(inode); |
inode | 397 | fs/ext/inode.c | static struct buffer_head * ext_update_inode(struct inode * inode) |
inode | 403 | fs/ext/inode.c | block = 2 + (inode->i_ino-1)/EXT_INODES_PER_BLOCK; |
inode | 404 | fs/ext/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) |
inode | 407 | fs/ext/inode.c | (inode->i_ino-1)%EXT_INODES_PER_BLOCK; |
inode | 408 | fs/ext/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 409 | fs/ext/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 410 | fs/ext/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 411 | fs/ext/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 412 | fs/ext/inode.c | raw_inode->i_size = inode->i_size; |
inode | 413 | fs/ext/inode.c | raw_inode->i_time = inode->i_mtime; |
inode | 414 | fs/ext/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 415 | fs/ext/inode.c | raw_inode->i_zone[0] = kdev_t_to_nr(inode->i_rdev); |
inode | 417 | fs/ext/inode.c | raw_inode->i_zone[block] = inode->u.ext_i.i_data[block]; |
inode | 419 | fs/ext/inode.c | inode->i_dirt=0; |
inode | 423 | fs/ext/inode.c | void ext_write_inode(struct inode * inode) |
inode | 426 | fs/ext/inode.c | bh = ext_update_inode (inode); |
inode | 430 | fs/ext/inode.c | int ext_sync_inode (struct inode *inode) |
inode | 435 | fs/ext/inode.c | bh = ext_update_inode(inode); |
inode | 444 | fs/ext/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 58 | fs/ext/namei.c | if (!de || !de->inode || len > EXT_NAME_LEN) |
inode | 79 | fs/ext/namei.c | static struct buffer_head * ext_find_entry(struct inode * dir, |
inode | 151 | fs/ext/namei.c | int ext_lookup(struct inode * dir,const char * name, int len, |
inode | 152 | fs/ext/namei.c | struct inode ** result) |
inode | 169 | fs/ext/namei.c | ino = de->inode; |
inode | 189 | fs/ext/namei.c | static struct buffer_head * ext_add_entry(struct inode * dir, |
inode | 236 | fs/ext/namei.c | de->inode = 0; |
inode | 259 | fs/ext/namei.c | de->inode=0; |
inode | 278 | fs/ext/namei.c | if (!de->inode && de->rec_len >= rec_len) { |
inode | 286 | fs/ext/namei.c | de1->inode = 0; |
inode | 307 | fs/ext/namei.c | int ext_create(struct inode * dir,const char * name, int len, int mode, |
inode | 308 | fs/ext/namei.c | struct inode ** result) |
inode | 310 | fs/ext/namei.c | struct inode * inode; |
inode | 317 | fs/ext/namei.c | inode = ext_new_inode(dir); |
inode | 318 | fs/ext/namei.c | if (!inode) { |
inode | 322 | fs/ext/namei.c | inode->i_op = &ext_file_inode_operations; |
inode | 323 | fs/ext/namei.c | inode->i_mode = mode; |
inode | 324 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 327 | fs/ext/namei.c | inode->i_nlink--; |
inode | 328 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 329 | fs/ext/namei.c | iput(inode); |
inode | 333 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 337 | fs/ext/namei.c | *result = inode; |
inode | 341 | fs/ext/namei.c | int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
inode | 343 | fs/ext/namei.c | struct inode * inode; |
inode | 355 | fs/ext/namei.c | inode = ext_new_inode(dir); |
inode | 356 | fs/ext/namei.c | if (!inode) { |
inode | 360 | fs/ext/namei.c | inode->i_uid = current->fsuid; |
inode | 361 | fs/ext/namei.c | inode->i_mode = mode; |
inode | 362 | fs/ext/namei.c | inode->i_op = NULL; |
inode | 363 | fs/ext/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 364 | fs/ext/namei.c | inode->i_op = &ext_file_inode_operations; |
inode | 365 | fs/ext/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 366 | fs/ext/namei.c | inode->i_op = &ext_dir_inode_operations; |
inode | 368 | fs/ext/namei.c | inode->i_mode |= S_ISGID; |
inode | 370 | fs/ext/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 371 | fs/ext/namei.c | inode->i_op = &ext_symlink_inode_operations; |
inode | 372 | fs/ext/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 373 | fs/ext/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 374 | fs/ext/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 375 | fs/ext/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 376 | fs/ext/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 377 | fs/ext/namei.c | init_fifo(inode); |
inode | 379 | fs/ext/namei.c | inode->i_rdev = to_kdev_t(rdev); |
inode | 381 | fs/ext/namei.c | inode->i_mtime = inode->i_atime = CURRENT_TIME; |
inode | 383 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 386 | fs/ext/namei.c | inode->i_nlink--; |
inode | 387 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 388 | fs/ext/namei.c | iput(inode); |
inode | 392 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 396 | fs/ext/namei.c | iput(inode); |
inode | 400 | fs/ext/namei.c | int ext_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 402 | fs/ext/namei.c | struct inode * inode; |
inode | 412 | fs/ext/namei.c | inode = ext_new_inode(dir); |
inode | 413 | fs/ext/namei.c | if (!inode) { |
inode | 417 | fs/ext/namei.c | inode->i_op = &ext_dir_inode_operations; |
inode | 418 | fs/ext/namei.c | inode->i_size = 2 * 16; /* Each entry is coded on 16 bytes for "." and ".." |
inode | 424 | fs/ext/namei.c | inode->i_mtime = inode->i_atime = CURRENT_TIME; |
inode | 426 | fs/ext/namei.c | dir_block = ext_bread(inode,0,1); |
inode | 429 | fs/ext/namei.c | inode->i_nlink--; |
inode | 430 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 431 | fs/ext/namei.c | iput(inode); |
inode | 435 | fs/ext/namei.c | de->inode=inode->i_ino; |
inode | 440 | fs/ext/namei.c | de->inode = dir->i_ino; |
inode | 444 | fs/ext/namei.c | inode->i_nlink = 2; |
inode | 447 | fs/ext/namei.c | inode->i_mode = S_IFDIR | (mode & 0777 & ~current->fs->umask); |
inode | 449 | fs/ext/namei.c | inode->i_mode |= S_ISGID; |
inode | 450 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 454 | fs/ext/namei.c | inode->i_nlink=0; |
inode | 455 | fs/ext/namei.c | iput(inode); |
inode | 458 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 463 | fs/ext/namei.c | iput(inode); |
inode | 471 | fs/ext/namei.c | static int empty_dir(struct inode * inode) |
inode | 477 | fs/ext/namei.c | if (inode->i_size < 2 * 12 || !(bh = ext_bread(inode,0,0))) { |
inode | 479 | fs/ext/namei.c | kdevname(inode->i_dev)); |
inode | 484 | fs/ext/namei.c | if (de->inode != inode->i_ino || !de1->inode || |
inode | 487 | fs/ext/namei.c | kdevname(inode->i_dev)); |
inode | 492 | fs/ext/namei.c | while (offset < inode->i_size ) { |
inode | 495 | fs/ext/namei.c | bh = ext_bread(inode, offset >> BLOCK_SIZE_BITS,1); |
inode | 507 | fs/ext/namei.c | kdevname(inode->i_dev), inode->i_ino, |
inode | 512 | fs/ext/namei.c | if (de->inode) { |
inode | 526 | fs/ext/namei.c | if (nde && !nde->inode) |
inode | 528 | fs/ext/namei.c | if (pde && !pde->inode) |
inode | 532 | fs/ext/namei.c | int ext_rmdir(struct inode * dir, const char * name, int len) |
inode | 535 | fs/ext/namei.c | struct inode * inode; |
inode | 539 | fs/ext/namei.c | inode = NULL; |
inode | 545 | fs/ext/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 548 | fs/ext/namei.c | current->fsuid != inode->i_uid && |
inode | 551 | fs/ext/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 553 | fs/ext/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 555 | fs/ext/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 559 | fs/ext/namei.c | if (!empty_dir(inode)) { |
inode | 563 | fs/ext/namei.c | if (inode->i_count > 1) { |
inode | 567 | fs/ext/namei.c | if (inode->i_nlink != 2) |
inode | 568 | fs/ext/namei.c | printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); |
inode | 569 | fs/ext/namei.c | de->inode = 0; |
inode | 573 | fs/ext/namei.c | inode->i_nlink=0; |
inode | 574 | fs/ext/namei.c | inode->i_dirt=1; |
inode | 576 | fs/ext/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 581 | fs/ext/namei.c | iput(inode); |
inode | 586 | fs/ext/namei.c | int ext_unlink(struct inode * dir, const char * name, int len) |
inode | 589 | fs/ext/namei.c | struct inode * inode; |
inode | 594 | fs/ext/namei.c | inode = NULL; |
inode | 598 | fs/ext/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 602 | fs/ext/namei.c | current->fsuid != inode->i_uid && |
inode | 605 | fs/ext/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 607 | fs/ext/namei.c | if (!inode->i_nlink) { |
inode | 609 | fs/ext/namei.c | kdevname(inode->i_dev), inode->i_ino, |
inode | 610 | fs/ext/namei.c | inode->i_nlink); |
inode | 611 | fs/ext/namei.c | inode->i_nlink=1; |
inode | 613 | fs/ext/namei.c | de->inode = 0; |
inode | 617 | fs/ext/namei.c | inode->i_nlink--; |
inode | 618 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 619 | fs/ext/namei.c | inode->i_ctime = CURRENT_TIME; |
inode | 620 | fs/ext/namei.c | dir->i_ctime = dir->i_mtime = inode->i_ctime; |
inode | 625 | fs/ext/namei.c | iput(inode); |
inode | 630 | fs/ext/namei.c | int ext_symlink(struct inode * dir, const char * name, int len, const char * symname) |
inode | 633 | fs/ext/namei.c | struct inode * inode = NULL; |
inode | 638 | fs/ext/namei.c | if (!(inode = ext_new_inode(dir))) { |
inode | 642 | fs/ext/namei.c | inode->i_mode = S_IFLNK | 0777; |
inode | 643 | fs/ext/namei.c | inode->i_op = &ext_symlink_inode_operations; |
inode | 644 | fs/ext/namei.c | name_block = ext_bread(inode,0,1); |
inode | 647 | fs/ext/namei.c | inode->i_nlink--; |
inode | 648 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 649 | fs/ext/namei.c | iput(inode); |
inode | 658 | fs/ext/namei.c | inode->i_size = i; |
inode | 659 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 662 | fs/ext/namei.c | inode->i_nlink--; |
inode | 663 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 664 | fs/ext/namei.c | iput(inode); |
inode | 671 | fs/ext/namei.c | inode->i_nlink--; |
inode | 672 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 673 | fs/ext/namei.c | iput(inode); |
inode | 677 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 681 | fs/ext/namei.c | iput(inode); |
inode | 685 | fs/ext/namei.c | int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
inode | 713 | fs/ext/namei.c | de->inode = oldinode->i_ino; |
inode | 724 | fs/ext/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 750 | fs/ext/namei.c | ((struct ext_dir_entry *) buffer)->rec_len))->inode |
inode | 766 | fs/ext/namei.c | static int do_ext_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 767 | fs/ext/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 769 | fs/ext/namei.c | struct inode * old_inode, * new_inode; |
inode | 790 | fs/ext/namei.c | old_inode = __iget(old_dir->i_sb, old_de->inode,0); /* don't cross mnt-points */ |
inode | 800 | fs/ext/namei.c | new_inode = __iget(new_dir->i_sb, new_de->inode,0); /* don't cross mnt-points */ |
inode | 841 | fs/ext/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 843 | fs/ext/namei.c | if (new_de->inode && !new_inode) |
inode | 845 | fs/ext/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 848 | fs/ext/namei.c | old_de->inode = 0; |
inode | 850 | fs/ext/namei.c | new_de->inode = old_inode->i_ino; |
inode | 887 | fs/ext/namei.c | int ext_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 888 | fs/ext/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 23 | fs/ext/symlink.c | static int ext_readlink(struct inode *, char *, int); |
inode | 24 | fs/ext/symlink.c | static int ext_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 49 | fs/ext/symlink.c | static int ext_follow_link(struct inode * dir, struct inode * inode, |
inode | 50 | fs/ext/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 60 | fs/ext/symlink.c | if (!inode) { |
inode | 64 | fs/ext/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 66 | fs/ext/symlink.c | *res_inode = inode; |
inode | 71 | fs/ext/symlink.c | iput(inode); |
inode | 74 | fs/ext/symlink.c | if (!(bh = ext_bread(inode, 0, 0))) { |
inode | 75 | fs/ext/symlink.c | iput(inode); |
inode | 79 | fs/ext/symlink.c | iput(inode); |
inode | 87 | fs/ext/symlink.c | static int ext_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 93 | fs/ext/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 94 | fs/ext/symlink.c | iput(inode); |
inode | 99 | fs/ext/symlink.c | bh = ext_bread(inode, 0, 0); |
inode | 100 | fs/ext/symlink.c | iput(inode); |
inode | 32 | fs/ext/truncate.c | static int trunc_direct(struct inode * inode) |
inode | 38 | fs/ext/truncate.c | #define DIRECT_BLOCK ((inode->i_size + 1023) >> 10) |
inode | 42 | fs/ext/truncate.c | p = inode->u.ext_i.i_data+i; |
inode | 45 | fs/ext/truncate.c | bh = getblk(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 56 | fs/ext/truncate.c | inode->i_dirt = 1; |
inode | 58 | fs/ext/truncate.c | ext_free_block(inode->i_sb,tmp); |
inode | 63 | fs/ext/truncate.c | static int trunc_indirect(struct inode * inode, int offset, unsigned long * p) |
inode | 75 | fs/ext/truncate.c | ind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 94 | fs/ext/truncate.c | bh = getblk(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 107 | fs/ext/truncate.c | ext_free_block(inode->i_sb,tmp); |
inode | 119 | fs/ext/truncate.c | inode->i_dirt = 1; |
inode | 120 | fs/ext/truncate.c | ext_free_block(inode->i_sb,tmp); |
inode | 126 | fs/ext/truncate.c | static int trunc_dindirect(struct inode * inode, int offset, unsigned long * p) |
inode | 137 | fs/ext/truncate.c | dind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 156 | fs/ext/truncate.c | retry |= trunc_indirect(inode,offset+(i<<8),dind); |
inode | 169 | fs/ext/truncate.c | inode->i_dirt = 1; |
inode | 170 | fs/ext/truncate.c | ext_free_block(inode->i_sb,tmp); |
inode | 176 | fs/ext/truncate.c | static int trunc_tindirect(struct inode * inode) |
inode | 184 | fs/ext/truncate.c | p = inode->u.ext_i.i_data+11; |
inode | 187 | fs/ext/truncate.c | tind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 203 | fs/ext/truncate.c | retry |= trunc_dindirect(inode,9+256+256*256+(i<<16),tind); |
inode | 216 | fs/ext/truncate.c | inode->i_dirt = 1; |
inode | 217 | fs/ext/truncate.c | ext_free_block(inode->i_sb,tmp); |
inode | 223 | fs/ext/truncate.c | void ext_truncate(struct inode * inode) |
inode | 227 | fs/ext/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 228 | fs/ext/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 231 | fs/ext/truncate.c | retry = trunc_direct(inode); |
inode | 232 | fs/ext/truncate.c | retry |= trunc_indirect(inode,9,inode->u.ext_i.i_data+9); |
inode | 233 | fs/ext/truncate.c | retry |= trunc_dindirect(inode,9+256,inode->u.ext_i.i_data+10); |
inode | 234 | fs/ext/truncate.c | retry |= trunc_tindirect(inode); |
inode | 240 | fs/ext/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 241 | fs/ext/truncate.c | inode->i_dirt = 1; |
inode | 249 | fs/ext/truncate.c | void ext_release(struct inode * inode, struct file * filp) |
inode | 26 | fs/ext2/acl.c | int ext2_permission (struct inode * inode, int mask) |
inode | 28 | fs/ext2/acl.c | unsigned short mode = inode->i_mode; |
inode | 33 | fs/ext2/acl.c | if ((mask & S_IWOTH) && IS_IMMUTABLE(inode)) |
inode | 43 | fs/ext2/acl.c | else if (current->fsuid == inode->i_uid) |
inode | 45 | fs/ext2/acl.c | else if (in_group_p (inode->i_gid)) |
inode | 168 | fs/ext2/balloc.c | void ext2_free_blocks (const struct inode * inode, unsigned long block, |
inode | 181 | fs/ext2/balloc.c | sb = inode->i_sb; |
inode | 230 | fs/ext2/balloc.c | sb->dq_op->free_block(inode, fs_to_dq_blocks(1, sb->s_blocksize)); |
inode | 256 | fs/ext2/balloc.c | int ext2_new_block (const struct inode * inode, unsigned long goal, |
inode | 272 | fs/ext2/balloc.c | sb = inode->i_sb; |
inode | 407 | fs/ext2/balloc.c | if (sb->dq_op->alloc_block (inode, fs_to_dq_blocks(1, sb->s_blocksize))) { |
inode | 427 | fs/ext2/balloc.c | sb->dq_op->free_block(inode, fs_to_dq_blocks(1, sb->s_blocksize)); |
inode | 443 | fs/ext2/balloc.c | if (sb->dq_op->alloc_block(inode, fs_to_dq_blocks(1, sb->s_blocksize))) |
inode | 447 | fs/ext2/balloc.c | sb->dq_op->free_block(inode, fs_to_dq_blocks(1, sb->s_blocksize)); |
inode | 26 | fs/ext2/dir.c | static int ext2_dir_read (struct inode * inode, struct file * filp, |
inode | 32 | fs/ext2/dir.c | static int ext2_readdir (struct inode *, struct file *, void *, filldir_t); |
inode | 74 | fs/ext2/dir.c | int ext2_check_dir_entry (const char * function, struct inode * dir, |
inode | 89 | fs/ext2/dir.c | else if (dir && de->inode > dir->i_sb->u.ext2_sb.s_es->s_inodes_count) |
inode | 95 | fs/ext2/dir.c | dir->i_ino, error_msg, offset, (unsigned long) de->inode, |
inode | 100 | fs/ext2/dir.c | static int ext2_readdir (struct inode * inode, struct file * filp, |
inode | 111 | fs/ext2/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 113 | fs/ext2/dir.c | sb = inode->i_sb; |
inode | 119 | fs/ext2/dir.c | while (!error && !stored && filp->f_pos < inode->i_size) { |
inode | 121 | fs/ext2/dir.c | bh = ext2_bread (inode, blk, 0, &err); |
inode | 125 | fs/ext2/dir.c | inode->i_ino, (unsigned long)filp->f_pos); |
inode | 136 | fs/ext2/dir.c | tmp = ext2_getblk (inode, ++blk, 0, &err); |
inode | 154 | fs/ext2/dir.c | if (filp->f_version != inode->i_version) { |
inode | 171 | fs/ext2/dir.c | filp->f_version = inode->i_version; |
inode | 174 | fs/ext2/dir.c | while (!error && filp->f_pos < inode->i_size |
inode | 177 | fs/ext2/dir.c | if (!ext2_check_dir_entry ("ext2_readdir", inode, de, |
inode | 187 | fs/ext2/dir.c | if (de->inode) { |
inode | 195 | fs/ext2/dir.c | dcache_add(inode, de->name, de->name_len, de->inode); |
inode | 196 | fs/ext2/dir.c | version = inode->i_version; |
inode | 197 | fs/ext2/dir.c | error = filldir(dirent, de->name, de->name_len, filp->f_pos, de->inode); |
inode | 200 | fs/ext2/dir.c | if (version != inode->i_version) |
inode | 209 | fs/ext2/dir.c | if (!IS_RDONLY(inode)) { |
inode | 210 | fs/ext2/dir.c | inode->i_atime = CURRENT_TIME; |
inode | 211 | fs/ext2/dir.c | inode->i_dirt = 1; |
inode | 39 | fs/ext2/file.c | static int ext2_file_write (struct inode *, struct file *, const char *, int); |
inode | 40 | fs/ext2/file.c | static void ext2_release_file (struct inode *, struct file *); |
inode | 83 | fs/ext2/file.c | static int ext2_file_write (struct inode * inode, struct file * filp, |
inode | 98 | fs/ext2/file.c | if (!inode) { |
inode | 102 | fs/ext2/file.c | sb = inode->i_sb; |
inode | 109 | fs/ext2/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 111 | fs/ext2/file.c | inode->i_mode); |
inode | 115 | fs/ext2/file.c | pos = inode->i_size; |
inode | 126 | fs/ext2/file.c | inode->u.ext2_i.i_osync++; |
inode | 137 | fs/ext2/file.c | bh = ext2_getblk (inode, block, 1, &err); |
inode | 157 | fs/ext2/file.c | update_vm_cache(inode, pos, bh->b_data + offset, c); |
inode | 193 | fs/ext2/file.c | if (pos > inode->i_size) |
inode | 194 | fs/ext2/file.c | inode->i_size = pos; |
inode | 196 | fs/ext2/file.c | inode->u.ext2_i.i_osync--; |
inode | 197 | fs/ext2/file.c | inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 199 | fs/ext2/file.c | inode->i_dirt = 1; |
inode | 208 | fs/ext2/file.c | static void ext2_release_file (struct inode * inode, struct file * filp) |
inode | 211 | fs/ext2/file.c | ext2_discard_prealloc (inode); |
inode | 27 | fs/ext2/fsync.c | #define blocksize (EXT2_BLOCK_SIZE(inode->i_sb)) |
inode | 28 | fs/ext2/fsync.c | #define addr_per_block (EXT2_ADDR_PER_BLOCK(inode->i_sb)) |
inode | 30 | fs/ext2/fsync.c | static int sync_block (struct inode * inode, u32 * block, int wait) |
inode | 38 | fs/ext2/fsync.c | bh = get_hash_table (inode->i_dev, *block, blocksize); |
inode | 58 | fs/ext2/fsync.c | static int sync_iblock (struct inode * inode, u32 * iblock, |
inode | 67 | fs/ext2/fsync.c | rc = sync_block (inode, iblock, wait); |
inode | 70 | fs/ext2/fsync.c | *bh = bread (inode->i_dev, tmp, blocksize); |
inode | 82 | fs/ext2/fsync.c | static int sync_direct (struct inode * inode, int wait) |
inode | 88 | fs/ext2/fsync.c | rc = sync_block (inode, inode->u.ext2_i.i_data + i, wait); |
inode | 97 | fs/ext2/fsync.c | static int sync_indirect (struct inode * inode, u32 * iblock, int wait) |
inode | 103 | fs/ext2/fsync.c | rc = sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 108 | fs/ext2/fsync.c | rc = sync_block (inode, |
inode | 120 | fs/ext2/fsync.c | static int sync_dindirect (struct inode * inode, u32 * diblock, int wait) |
inode | 126 | fs/ext2/fsync.c | rc = sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 131 | fs/ext2/fsync.c | rc = sync_indirect (inode, |
inode | 143 | fs/ext2/fsync.c | static int sync_tindirect (struct inode * inode, u32 * tiblock, int wait) |
inode | 149 | fs/ext2/fsync.c | rc = sync_iblock (inode, tiblock, &tind_bh, wait); |
inode | 154 | fs/ext2/fsync.c | rc = sync_dindirect (inode, |
inode | 166 | fs/ext2/fsync.c | int ext2_sync_file (struct inode * inode, struct file * file) |
inode | 170 | fs/ext2/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 171 | fs/ext2/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 173 | fs/ext2/fsync.c | if (S_ISLNK(inode->i_mode) && !(inode->i_blocks)) |
inode | 181 | fs/ext2/fsync.c | err |= sync_direct (inode, wait); |
inode | 182 | fs/ext2/fsync.c | err |= sync_indirect (inode, |
inode | 183 | fs/ext2/fsync.c | inode->u.ext2_i.i_data+EXT2_IND_BLOCK, |
inode | 185 | fs/ext2/fsync.c | err |= sync_dindirect (inode, |
inode | 186 | fs/ext2/fsync.c | inode->u.ext2_i.i_data+EXT2_DIND_BLOCK, |
inode | 188 | fs/ext2/fsync.c | err |= sync_tindirect (inode, |
inode | 189 | fs/ext2/fsync.c | inode->u.ext2_i.i_data+EXT2_TIND_BLOCK, |
inode | 193 | fs/ext2/fsync.c | err |= ext2_sync_inode (inode); |
inode | 159 | fs/ext2/ialloc.c | static void set_inode_dtime (struct inode * inode, |
inode | 166 | fs/ext2/ialloc.c | inode_block = gdp->bg_inode_table + (((inode->i_ino - 1) % |
inode | 167 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) / |
inode | 168 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 169 | fs/ext2/ialloc.c | bh = bread (inode->i_sb->s_dev, inode_block, inode->i_sb->s_blocksize); |
inode | 171 | fs/ext2/ialloc.c | ext2_panic (inode->i_sb, "set_inode_dtime", |
inode | 174 | fs/ext2/ialloc.c | inode->i_ino, inode_block); |
inode | 176 | fs/ext2/ialloc.c | (((inode->i_ino - 1) % |
inode | 177 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) % |
inode | 178 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 182 | fs/ext2/ialloc.c | if (IS_SYNC(inode)) { |
inode | 189 | fs/ext2/ialloc.c | void ext2_free_inode (struct inode * inode) |
inode | 200 | fs/ext2/ialloc.c | if (!inode) |
inode | 202 | fs/ext2/ialloc.c | if (!inode->i_dev) { |
inode | 206 | fs/ext2/ialloc.c | if (inode->i_count > 1) { |
inode | 208 | fs/ext2/ialloc.c | inode->i_count); |
inode | 211 | fs/ext2/ialloc.c | if (inode->i_nlink) { |
inode | 213 | fs/ext2/ialloc.c | inode->i_nlink); |
inode | 216 | fs/ext2/ialloc.c | if (!inode->i_sb) { |
inode | 221 | fs/ext2/ialloc.c | ext2_debug ("freeing inode %lu\n", inode->i_ino); |
inode | 223 | fs/ext2/ialloc.c | sb = inode->i_sb; |
inode | 225 | fs/ext2/ialloc.c | if (inode->i_ino < EXT2_FIRST_INO || |
inode | 226 | fs/ext2/ialloc.c | inode->i_ino > sb->u.ext2_sb.s_es->s_inodes_count) { |
inode | 233 | fs/ext2/ialloc.c | block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(sb); |
inode | 234 | fs/ext2/ialloc.c | bit = (inode->i_ino - 1) % EXT2_INODES_PER_GROUP(sb); |
inode | 239 | fs/ext2/ialloc.c | "bit already cleared for inode %lu", inode->i_ino); |
inode | 243 | fs/ext2/ialloc.c | if (S_ISDIR(inode->i_mode)) |
inode | 248 | fs/ext2/ialloc.c | inode->i_dirt = 0; |
inode | 249 | fs/ext2/ialloc.c | set_inode_dtime (inode, gdp); |
inode | 257 | fs/ext2/ialloc.c | sb->dq_op->free_inode (inode, 1); |
inode | 259 | fs/ext2/ialloc.c | clear_inode (inode); |
inode | 268 | fs/ext2/ialloc.c | static void inc_inode_version (struct inode * inode, |
inode | 276 | fs/ext2/ialloc.c | inode_block = gdp->bg_inode_table + (((inode->i_ino - 1) % |
inode | 277 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) / |
inode | 278 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 279 | fs/ext2/ialloc.c | bh = bread (inode->i_sb->s_dev, inode_block, inode->i_sb->s_blocksize); |
inode | 281 | fs/ext2/ialloc.c | ext2_error (inode->i_sb, "inc_inode_version", |
inode | 284 | fs/ext2/ialloc.c | inode->i_ino, inode_block); |
inode | 285 | fs/ext2/ialloc.c | inode->u.ext2_i.i_version = 1; |
inode | 289 | fs/ext2/ialloc.c | (((inode->i_ino - 1) % |
inode | 290 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) % |
inode | 291 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 293 | fs/ext2/ialloc.c | inode->u.ext2_i.i_version = raw_inode->i_version; |
inode | 308 | fs/ext2/ialloc.c | struct inode * ext2_new_inode (const struct inode * dir, int mode, int * err) |
inode | 314 | fs/ext2/ialloc.c | struct inode * inode; |
inode | 320 | fs/ext2/ialloc.c | if (!dir || !(inode = get_empty_inode ())) |
inode | 323 | fs/ext2/ialloc.c | inode->i_sb = sb; |
inode | 324 | fs/ext2/ialloc.c | inode->i_flags = sb->s_flags; |
inode | 407 | fs/ext2/ialloc.c | iput(inode); |
inode | 431 | fs/ext2/ialloc.c | iput (inode); |
inode | 442 | fs/ext2/ialloc.c | iput (inode); |
inode | 452 | fs/ext2/ialloc.c | inode->i_mode = mode; |
inode | 453 | fs/ext2/ialloc.c | inode->i_sb = sb; |
inode | 454 | fs/ext2/ialloc.c | inode->i_count = 1; |
inode | 455 | fs/ext2/ialloc.c | inode->i_nlink = 1; |
inode | 456 | fs/ext2/ialloc.c | inode->i_dev = sb->s_dev; |
inode | 457 | fs/ext2/ialloc.c | inode->i_uid = current->fsuid; |
inode | 459 | fs/ext2/ialloc.c | inode->i_gid = dir->i_gid; |
inode | 461 | fs/ext2/ialloc.c | inode->i_gid = dir->i_gid; |
inode | 465 | fs/ext2/ialloc.c | inode->i_gid = current->fsgid; |
inode | 466 | fs/ext2/ialloc.c | inode->i_dirt = 1; |
inode | 467 | fs/ext2/ialloc.c | inode->i_ino = j; |
inode | 468 | fs/ext2/ialloc.c | inode->i_blksize = PAGE_SIZE; /* This is the optimal IO size (for stat), not the fs block size */ |
inode | 469 | fs/ext2/ialloc.c | inode->i_blocks = 0; |
inode | 470 | fs/ext2/ialloc.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 471 | fs/ext2/ialloc.c | inode->u.ext2_i.i_flags = dir->u.ext2_i.i_flags; |
inode | 473 | fs/ext2/ialloc.c | inode->u.ext2_i.i_flags &= ~(EXT2_IMMUTABLE_FL | EXT2_APPEND_FL); |
inode | 474 | fs/ext2/ialloc.c | inode->u.ext2_i.i_faddr = 0; |
inode | 475 | fs/ext2/ialloc.c | inode->u.ext2_i.i_frag_no = 0; |
inode | 476 | fs/ext2/ialloc.c | inode->u.ext2_i.i_frag_size = 0; |
inode | 477 | fs/ext2/ialloc.c | inode->u.ext2_i.i_file_acl = 0; |
inode | 478 | fs/ext2/ialloc.c | inode->u.ext2_i.i_dir_acl = 0; |
inode | 479 | fs/ext2/ialloc.c | inode->u.ext2_i.i_dtime = 0; |
inode | 480 | fs/ext2/ialloc.c | inode->u.ext2_i.i_block_group = i; |
inode | 481 | fs/ext2/ialloc.c | inode->i_op = NULL; |
inode | 482 | fs/ext2/ialloc.c | if (inode->u.ext2_i.i_flags & EXT2_SYNC_FL) |
inode | 483 | fs/ext2/ialloc.c | inode->i_flags |= MS_SYNCHRONOUS; |
inode | 484 | fs/ext2/ialloc.c | insert_inode_hash(inode); |
inode | 485 | fs/ext2/ialloc.c | inc_inode_version (inode, gdp, mode); |
inode | 489 | fs/ext2/ialloc.c | sb->dq_op->initialize (inode, -1); |
inode | 490 | fs/ext2/ialloc.c | if (sb->dq_op->alloc_inode (inode, 1)) { |
inode | 491 | fs/ext2/ialloc.c | sb->dq_op->drop (inode); |
inode | 492 | fs/ext2/ialloc.c | inode->i_nlink = 0; |
inode | 493 | fs/ext2/ialloc.c | iput (inode); |
inode | 497 | fs/ext2/ialloc.c | inode->i_flags |= S_WRITE; |
inode | 499 | fs/ext2/ialloc.c | ext2_debug ("allocating inode %lu\n", inode->i_ino); |
inode | 502 | fs/ext2/ialloc.c | return inode; |
inode | 30 | fs/ext2/inode.c | void ext2_put_inode (struct inode * inode) |
inode | 32 | fs/ext2/inode.c | ext2_discard_prealloc (inode); |
inode | 33 | fs/ext2/inode.c | if (inode->i_nlink || inode->i_ino == EXT2_ACL_IDX_INO || |
inode | 34 | fs/ext2/inode.c | inode->i_ino == EXT2_ACL_DATA_INO) |
inode | 36 | fs/ext2/inode.c | inode->i_size = 0; |
inode | 37 | fs/ext2/inode.c | if (inode->i_blocks) |
inode | 38 | fs/ext2/inode.c | ext2_truncate (inode); |
inode | 39 | fs/ext2/inode.c | ext2_free_inode (inode); |
inode | 42 | fs/ext2/inode.c | #define inode_bmap(inode, nr) ((inode)->u.ext2_i.i_data[(nr)]) |
inode | 62 | fs/ext2/inode.c | void ext2_discard_prealloc (struct inode * inode) |
inode | 67 | fs/ext2/inode.c | if (inode->u.ext2_i.i_prealloc_count) { |
inode | 68 | fs/ext2/inode.c | total = inode->u.ext2_i.i_prealloc_count; |
inode | 69 | fs/ext2/inode.c | inode->u.ext2_i.i_prealloc_count = 0; |
inode | 70 | fs/ext2/inode.c | ext2_free_blocks (inode, inode->u.ext2_i.i_prealloc_block, total); |
inode | 75 | fs/ext2/inode.c | static int ext2_alloc_block (struct inode * inode, unsigned long goal, int * err) |
inode | 83 | fs/ext2/inode.c | wait_on_super (inode->i_sb); |
inode | 86 | fs/ext2/inode.c | if (inode->u.ext2_i.i_prealloc_count && |
inode | 87 | fs/ext2/inode.c | (goal == inode->u.ext2_i.i_prealloc_block || |
inode | 88 | fs/ext2/inode.c | goal + 1 == inode->u.ext2_i.i_prealloc_block)) |
inode | 90 | fs/ext2/inode.c | result = inode->u.ext2_i.i_prealloc_block++; |
inode | 91 | fs/ext2/inode.c | inode->u.ext2_i.i_prealloc_count--; |
inode | 98 | fs/ext2/inode.c | if (!(bh = getblk (inode->i_sb->s_dev, result, |
inode | 99 | fs/ext2/inode.c | inode->i_sb->s_blocksize))) { |
inode | 100 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_alloc_block", |
inode | 104 | fs/ext2/inode.c | memset(bh->b_data, 0, inode->i_sb->s_blocksize); |
inode | 109 | fs/ext2/inode.c | ext2_discard_prealloc (inode); |
inode | 112 | fs/ext2/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 113 | fs/ext2/inode.c | result = ext2_new_block (inode, goal, |
inode | 114 | fs/ext2/inode.c | &inode->u.ext2_i.i_prealloc_count, |
inode | 115 | fs/ext2/inode.c | &inode->u.ext2_i.i_prealloc_block, err); |
inode | 117 | fs/ext2/inode.c | result = ext2_new_block (inode, goal, 0, 0, err); |
inode | 120 | fs/ext2/inode.c | result = ext2_new_block (inode, goal, 0, 0, err); |
inode | 127 | fs/ext2/inode.c | int ext2_bmap (struct inode * inode, int block) |
inode | 130 | fs/ext2/inode.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 131 | fs/ext2/inode.c | int addr_per_block_bits = EXT2_ADDR_PER_BLOCK_BITS(inode->i_sb); |
inode | 134 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_bmap", "block < 0"); |
inode | 140 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_bmap", "block > big"); |
inode | 144 | fs/ext2/inode.c | return inode_bmap (inode, block); |
inode | 147 | fs/ext2/inode.c | i = inode_bmap (inode, EXT2_IND_BLOCK); |
inode | 150 | fs/ext2/inode.c | return block_bmap (bread (inode->i_dev, i, |
inode | 151 | fs/ext2/inode.c | inode->i_sb->s_blocksize), block); |
inode | 155 | fs/ext2/inode.c | i = inode_bmap (inode, EXT2_DIND_BLOCK); |
inode | 158 | fs/ext2/inode.c | i = block_bmap (bread (inode->i_dev, i, |
inode | 159 | fs/ext2/inode.c | inode->i_sb->s_blocksize), |
inode | 163 | fs/ext2/inode.c | return block_bmap (bread (inode->i_dev, i, |
inode | 164 | fs/ext2/inode.c | inode->i_sb->s_blocksize), |
inode | 168 | fs/ext2/inode.c | i = inode_bmap (inode, EXT2_TIND_BLOCK); |
inode | 171 | fs/ext2/inode.c | i = block_bmap (bread (inode->i_dev, i, inode->i_sb->s_blocksize), |
inode | 175 | fs/ext2/inode.c | i = block_bmap (bread (inode->i_dev, i, inode->i_sb->s_blocksize), |
inode | 179 | fs/ext2/inode.c | return block_bmap (bread (inode->i_dev, i, inode->i_sb->s_blocksize), |
inode | 183 | fs/ext2/inode.c | static struct buffer_head * inode_getblk (struct inode * inode, int nr, |
inode | 189 | fs/ext2/inode.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 191 | fs/ext2/inode.c | p = inode->u.ext2_i.i_data + nr; |
inode | 195 | fs/ext2/inode.c | result = getblk (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 203 | fs/ext2/inode.c | EXT2_BLOCK_SIZE_BITS(inode->i_sb))) { |
inode | 207 | fs/ext2/inode.c | if (inode->u.ext2_i.i_next_alloc_block == new_block) |
inode | 208 | fs/ext2/inode.c | goal = inode->u.ext2_i.i_next_alloc_goal; |
inode | 214 | fs/ext2/inode.c | if (inode->u.ext2_i.i_data[tmp]) { |
inode | 215 | fs/ext2/inode.c | goal = inode->u.ext2_i.i_data[tmp]; |
inode | 220 | fs/ext2/inode.c | goal = (inode->u.ext2_i.i_block_group * |
inode | 221 | fs/ext2/inode.c | EXT2_BLOCKS_PER_GROUP(inode->i_sb)) + |
inode | 222 | fs/ext2/inode.c | inode->i_sb->u.ext2_sb.s_es->s_first_data_block; |
inode | 227 | fs/ext2/inode.c | tmp = ext2_alloc_block (inode, goal, err); |
inode | 230 | fs/ext2/inode.c | result = getblk (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 232 | fs/ext2/inode.c | ext2_free_blocks (inode, tmp, 1); |
inode | 237 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block = new_block; |
inode | 238 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal = tmp; |
inode | 239 | fs/ext2/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 240 | fs/ext2/inode.c | inode->i_blocks += blocks; |
inode | 241 | fs/ext2/inode.c | if (IS_SYNC(inode) || inode->u.ext2_i.i_osync) |
inode | 242 | fs/ext2/inode.c | ext2_sync_inode (inode); |
inode | 244 | fs/ext2/inode.c | inode->i_dirt = 1; |
inode | 248 | fs/ext2/inode.c | static struct buffer_head * block_getblk (struct inode * inode, |
inode | 256 | fs/ext2/inode.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 282 | fs/ext2/inode.c | EXT2_BLOCK_SIZE_BITS(inode->i_sb))) { |
inode | 287 | fs/ext2/inode.c | if (inode->u.ext2_i.i_next_alloc_block == new_block) |
inode | 288 | fs/ext2/inode.c | goal = inode->u.ext2_i.i_next_alloc_goal; |
inode | 299 | fs/ext2/inode.c | tmp = ext2_alloc_block (inode, goal, err); |
inode | 306 | fs/ext2/inode.c | ext2_free_blocks (inode, tmp, 1); |
inode | 312 | fs/ext2/inode.c | if (IS_SYNC(inode) || inode->u.ext2_i.i_osync) { |
inode | 316 | fs/ext2/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 317 | fs/ext2/inode.c | inode->i_blocks += blocks; |
inode | 318 | fs/ext2/inode.c | inode->i_dirt = 1; |
inode | 319 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block = new_block; |
inode | 320 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal = tmp; |
inode | 325 | fs/ext2/inode.c | static int block_getcluster (struct inode * inode, struct buffer_head * bh, |
inode | 338 | fs/ext2/inode.c | if((nr & ((PAGE_SIZE >> EXT2_BLOCK_SIZE_BITS(inode->i_sb)) - 1)) != 0) |
inode | 340 | fs/ext2/inode.c | if(nr + 3 > EXT2_ADDR_PER_BLOCK(inode->i_sb)) goto out; |
inode | 342 | fs/ext2/inode.c | for(i=0; i< (PAGE_SIZE >> EXT2_BLOCK_SIZE_BITS(inode->i_sb)); i++) { |
inode | 361 | fs/ext2/inode.c | struct buffer_head * ext2_getblk (struct inode * inode, long block, |
inode | 366 | fs/ext2/inode.c | unsigned long addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 367 | fs/ext2/inode.c | int addr_per_block_bits = EXT2_ADDR_PER_BLOCK_BITS(inode->i_sb); |
inode | 371 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block < 0"); |
inode | 377 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block > big"); |
inode | 387 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block, |
inode | 388 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal); |
inode | 390 | fs/ext2/inode.c | if (block == inode->u.ext2_i.i_next_alloc_block + 1) { |
inode | 391 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block++; |
inode | 392 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal++; |
inode | 398 | fs/ext2/inode.c | return inode_getblk (inode, block, create, b, err); |
inode | 401 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_IND_BLOCK, create, b, err); |
inode | 402 | fs/ext2/inode.c | return block_getblk (inode, bh, block, create, |
inode | 403 | fs/ext2/inode.c | inode->i_sb->s_blocksize, b, err); |
inode | 407 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_DIND_BLOCK, create, b, err); |
inode | 408 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block >> addr_per_block_bits, |
inode | 409 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 410 | fs/ext2/inode.c | return block_getblk (inode, bh, block & (addr_per_block - 1), |
inode | 411 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 414 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_TIND_BLOCK, create, b, err); |
inode | 415 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block >> (addr_per_block_bits * 2), |
inode | 416 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 417 | fs/ext2/inode.c | bh = block_getblk (inode, bh, (block >> addr_per_block_bits) & (addr_per_block - 1), |
inode | 418 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 419 | fs/ext2/inode.c | return block_getblk (inode, bh, block & (addr_per_block - 1), create, |
inode | 420 | fs/ext2/inode.c | inode->i_sb->s_blocksize, b, err); |
inode | 423 | fs/ext2/inode.c | int ext2_getcluster (struct inode * inode, long block) |
inode | 428 | fs/ext2/inode.c | unsigned long addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 429 | fs/ext2/inode.c | int addr_per_block_bits = EXT2_ADDR_PER_BLOCK_BITS(inode->i_sb); |
inode | 434 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block < 0"); |
inode | 440 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block > big"); |
inode | 451 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_IND_BLOCK, create, b, &err); |
inode | 452 | fs/ext2/inode.c | return block_getcluster (inode, bh, block, |
inode | 453 | fs/ext2/inode.c | inode->i_sb->s_blocksize); |
inode | 457 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_DIND_BLOCK, create, b, &err); |
inode | 458 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block >> addr_per_block_bits, |
inode | 459 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, &err); |
inode | 460 | fs/ext2/inode.c | return block_getcluster (inode, bh, block & (addr_per_block - 1), |
inode | 461 | fs/ext2/inode.c | inode->i_sb->s_blocksize); |
inode | 464 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_TIND_BLOCK, create, b, &err); |
inode | 465 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block >> (addr_per_block_bits * 2), |
inode | 466 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, &err); |
inode | 467 | fs/ext2/inode.c | bh = block_getblk (inode, bh, (block >> addr_per_block_bits) & (addr_per_block - 1), |
inode | 468 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, &err); |
inode | 469 | fs/ext2/inode.c | return block_getcluster (inode, bh, block & (addr_per_block - 1), |
inode | 470 | fs/ext2/inode.c | inode->i_sb->s_blocksize); |
inode | 473 | fs/ext2/inode.c | struct buffer_head * ext2_bread (struct inode * inode, int block, |
inode | 478 | fs/ext2/inode.c | bh = ext2_getblk (inode, block, create, err); |
inode | 490 | fs/ext2/inode.c | void ext2_read_inode (struct inode * inode) |
inode | 500 | fs/ext2/inode.c | if ((inode->i_ino != EXT2_ROOT_INO && inode->i_ino != EXT2_ACL_IDX_INO && |
inode | 501 | fs/ext2/inode.c | inode->i_ino != EXT2_ACL_DATA_INO && inode->i_ino < EXT2_FIRST_INO) || |
inode | 502 | fs/ext2/inode.c | inode->i_ino > inode->i_sb->u.ext2_sb.s_es->s_inodes_count) { |
inode | 503 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_read_inode", |
inode | 504 | fs/ext2/inode.c | "bad inode number: %lu", inode->i_ino); |
inode | 507 | fs/ext2/inode.c | block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(inode->i_sb); |
inode | 508 | fs/ext2/inode.c | if (block_group >= inode->i_sb->u.ext2_sb.s_groups_count) |
inode | 509 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_read_inode", |
inode | 511 | fs/ext2/inode.c | group_desc = block_group >> EXT2_DESC_PER_BLOCK_BITS(inode->i_sb); |
inode | 512 | fs/ext2/inode.c | desc = block_group & (EXT2_DESC_PER_BLOCK(inode->i_sb) - 1); |
inode | 513 | fs/ext2/inode.c | bh = inode->i_sb->u.ext2_sb.s_group_desc[group_desc]; |
inode | 515 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_read_inode", |
inode | 519 | fs/ext2/inode.c | (((inode->i_ino - 1) % EXT2_INODES_PER_GROUP(inode->i_sb)) |
inode | 520 | fs/ext2/inode.c | >> EXT2_INODES_PER_BLOCK_BITS(inode->i_sb)); |
inode | 521 | fs/ext2/inode.c | if (!(bh = bread (inode->i_dev, block, inode->i_sb->s_blocksize))) |
inode | 522 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_read_inode", |
inode | 524 | fs/ext2/inode.c | "inode=%lu, block=%lu", inode->i_ino, block); |
inode | 526 | fs/ext2/inode.c | ((inode->i_ino - 1) & (EXT2_INODES_PER_BLOCK(inode->i_sb) - 1)); |
inode | 527 | fs/ext2/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 528 | fs/ext2/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 529 | fs/ext2/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 530 | fs/ext2/inode.c | inode->i_nlink = raw_inode->i_links_count; |
inode | 531 | fs/ext2/inode.c | inode->i_size = raw_inode->i_size; |
inode | 532 | fs/ext2/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 533 | fs/ext2/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 534 | fs/ext2/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 535 | fs/ext2/inode.c | inode->u.ext2_i.i_dtime = raw_inode->i_dtime; |
inode | 536 | fs/ext2/inode.c | inode->i_blksize = PAGE_SIZE; /* This is the optimal IO size (for stat), not the fs block size */ |
inode | 537 | fs/ext2/inode.c | inode->i_blocks = raw_inode->i_blocks; |
inode | 538 | fs/ext2/inode.c | inode->i_version = ++event; |
inode | 539 | fs/ext2/inode.c | inode->u.ext2_i.i_flags = raw_inode->i_flags; |
inode | 540 | fs/ext2/inode.c | inode->u.ext2_i.i_faddr = raw_inode->i_faddr; |
inode | 541 | fs/ext2/inode.c | inode->u.ext2_i.i_frag_no = raw_inode->i_frag; |
inode | 542 | fs/ext2/inode.c | inode->u.ext2_i.i_frag_size = raw_inode->i_fsize; |
inode | 543 | fs/ext2/inode.c | inode->u.ext2_i.i_osync = 0; |
inode | 544 | fs/ext2/inode.c | inode->u.ext2_i.i_file_acl = raw_inode->i_file_acl; |
inode | 545 | fs/ext2/inode.c | inode->u.ext2_i.i_dir_acl = raw_inode->i_dir_acl; |
inode | 546 | fs/ext2/inode.c | inode->u.ext2_i.i_version = raw_inode->i_version; |
inode | 547 | fs/ext2/inode.c | inode->u.ext2_i.i_block_group = block_group; |
inode | 548 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block = 0; |
inode | 549 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal = 0; |
inode | 550 | fs/ext2/inode.c | if (inode->u.ext2_i.i_prealloc_count) |
inode | 551 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_read_inode", |
inode | 553 | fs/ext2/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 554 | fs/ext2/inode.c | inode->i_rdev = to_kdev_t(raw_inode->i_block[0]); |
inode | 556 | fs/ext2/inode.c | inode->u.ext2_i.i_data[block] = raw_inode->i_block[block]; |
inode | 558 | fs/ext2/inode.c | inode->i_op = NULL; |
inode | 559 | fs/ext2/inode.c | if (inode->i_ino == EXT2_ACL_IDX_INO || |
inode | 560 | fs/ext2/inode.c | inode->i_ino == EXT2_ACL_DATA_INO) |
inode | 562 | fs/ext2/inode.c | else if (S_ISREG(inode->i_mode)) |
inode | 563 | fs/ext2/inode.c | inode->i_op = &ext2_file_inode_operations; |
inode | 564 | fs/ext2/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 565 | fs/ext2/inode.c | inode->i_op = &ext2_dir_inode_operations; |
inode | 566 | fs/ext2/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 567 | fs/ext2/inode.c | inode->i_op = &ext2_symlink_inode_operations; |
inode | 568 | fs/ext2/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 569 | fs/ext2/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 570 | fs/ext2/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 571 | fs/ext2/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 572 | fs/ext2/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 573 | fs/ext2/inode.c | init_fifo(inode); |
inode | 574 | fs/ext2/inode.c | if (inode->u.ext2_i.i_flags & EXT2_SYNC_FL) |
inode | 575 | fs/ext2/inode.c | inode->i_flags |= MS_SYNCHRONOUS; |
inode | 576 | fs/ext2/inode.c | if (inode->u.ext2_i.i_flags & EXT2_APPEND_FL) |
inode | 577 | fs/ext2/inode.c | inode->i_flags |= S_APPEND; |
inode | 578 | fs/ext2/inode.c | if (inode->u.ext2_i.i_flags & EXT2_IMMUTABLE_FL) |
inode | 579 | fs/ext2/inode.c | inode->i_flags |= S_IMMUTABLE; |
inode | 582 | fs/ext2/inode.c | static struct buffer_head * ext2_update_inode (struct inode * inode) |
inode | 592 | fs/ext2/inode.c | if ((inode->i_ino != EXT2_ROOT_INO && inode->i_ino < EXT2_FIRST_INO) || |
inode | 593 | fs/ext2/inode.c | inode->i_ino > inode->i_sb->u.ext2_sb.s_es->s_inodes_count) { |
inode | 594 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_write_inode", |
inode | 595 | fs/ext2/inode.c | "bad inode number: %lu", inode->i_ino); |
inode | 598 | fs/ext2/inode.c | block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(inode->i_sb); |
inode | 599 | fs/ext2/inode.c | if (block_group >= inode->i_sb->u.ext2_sb.s_groups_count) |
inode | 600 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_write_inode", |
inode | 602 | fs/ext2/inode.c | group_desc = block_group >> EXT2_DESC_PER_BLOCK_BITS(inode->i_sb); |
inode | 603 | fs/ext2/inode.c | desc = block_group & (EXT2_DESC_PER_BLOCK(inode->i_sb) - 1); |
inode | 604 | fs/ext2/inode.c | bh = inode->i_sb->u.ext2_sb.s_group_desc[group_desc]; |
inode | 606 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_write_inode", |
inode | 610 | fs/ext2/inode.c | (((inode->i_ino - 1) % EXT2_INODES_PER_GROUP(inode->i_sb)) |
inode | 611 | fs/ext2/inode.c | >> EXT2_INODES_PER_BLOCK_BITS(inode->i_sb)); |
inode | 612 | fs/ext2/inode.c | if (!(bh = bread (inode->i_dev, block, inode->i_sb->s_blocksize))) |
inode | 613 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_write_inode", |
inode | 615 | fs/ext2/inode.c | "inode=%lu, block=%lu", inode->i_ino, block); |
inode | 617 | fs/ext2/inode.c | (inode->i_ino - 1) % EXT2_INODES_PER_BLOCK(inode->i_sb); |
inode | 618 | fs/ext2/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 619 | fs/ext2/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 620 | fs/ext2/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 621 | fs/ext2/inode.c | raw_inode->i_links_count = inode->i_nlink; |
inode | 622 | fs/ext2/inode.c | raw_inode->i_size = inode->i_size; |
inode | 623 | fs/ext2/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 624 | fs/ext2/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 625 | fs/ext2/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 626 | fs/ext2/inode.c | raw_inode->i_blocks = inode->i_blocks; |
inode | 627 | fs/ext2/inode.c | raw_inode->i_dtime = inode->u.ext2_i.i_dtime; |
inode | 628 | fs/ext2/inode.c | raw_inode->i_flags = inode->u.ext2_i.i_flags; |
inode | 629 | fs/ext2/inode.c | raw_inode->i_faddr = inode->u.ext2_i.i_faddr; |
inode | 630 | fs/ext2/inode.c | raw_inode->i_frag = inode->u.ext2_i.i_frag_no; |
inode | 631 | fs/ext2/inode.c | raw_inode->i_fsize = inode->u.ext2_i.i_frag_size; |
inode | 632 | fs/ext2/inode.c | raw_inode->i_file_acl = inode->u.ext2_i.i_file_acl; |
inode | 633 | fs/ext2/inode.c | raw_inode->i_dir_acl = inode->u.ext2_i.i_dir_acl; |
inode | 634 | fs/ext2/inode.c | raw_inode->i_version = inode->u.ext2_i.i_version; |
inode | 635 | fs/ext2/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 636 | fs/ext2/inode.c | raw_inode->i_block[0] = kdev_t_to_nr(inode->i_rdev); |
inode | 638 | fs/ext2/inode.c | raw_inode->i_block[block] = inode->u.ext2_i.i_data[block]; |
inode | 640 | fs/ext2/inode.c | inode->i_dirt = 0; |
inode | 644 | fs/ext2/inode.c | void ext2_write_inode (struct inode * inode) |
inode | 647 | fs/ext2/inode.c | bh = ext2_update_inode (inode); |
inode | 651 | fs/ext2/inode.c | int ext2_sync_inode (struct inode *inode) |
inode | 656 | fs/ext2/inode.c | bh = ext2_update_inode (inode); |
inode | 665 | fs/ext2/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 19 | fs/ext2/ioctl.c | int ext2_ioctl (struct inode * inode, struct file * filp, unsigned int cmd, |
inode | 31 | fs/ext2/ioctl.c | put_fs_long (inode->u.ext2_i.i_flags, (long *) arg); |
inode | 40 | fs/ext2/ioctl.c | (inode->u.ext2_i.i_flags & EXT2_IMMUTABLE_FL)) { |
inode | 45 | fs/ext2/ioctl.c | if ((current->fsuid != inode->i_uid) && !fsuser()) |
inode | 47 | fs/ext2/ioctl.c | if (IS_RDONLY(inode)) |
inode | 49 | fs/ext2/ioctl.c | inode->u.ext2_i.i_flags = flags; |
inode | 51 | fs/ext2/ioctl.c | inode->i_flags |= S_APPEND; |
inode | 53 | fs/ext2/ioctl.c | inode->i_flags &= ~S_APPEND; |
inode | 55 | fs/ext2/ioctl.c | inode->i_flags |= S_IMMUTABLE; |
inode | 57 | fs/ext2/ioctl.c | inode->i_flags &= ~S_IMMUTABLE; |
inode | 58 | fs/ext2/ioctl.c | inode->i_ctime = CURRENT_TIME; |
inode | 59 | fs/ext2/ioctl.c | inode->i_dirt = 1; |
inode | 64 | fs/ext2/ioctl.c | put_fs_long (inode->u.ext2_i.i_version, (long *) arg); |
inode | 67 | fs/ext2/ioctl.c | if ((current->fsuid != inode->i_uid) && !fsuser()) |
inode | 69 | fs/ext2/ioctl.c | if (IS_RDONLY(inode)) |
inode | 71 | fs/ext2/ioctl.c | inode->u.ext2_i.i_version = get_fs_long ((long *) arg); |
inode | 72 | fs/ext2/ioctl.c | inode->i_ctime = CURRENT_TIME; |
inode | 73 | fs/ext2/ioctl.c | inode->i_dirt = 1; |
inode | 47 | fs/ext2/namei.c | if (!de || !de->inode || len > EXT2_NAME_LEN) |
inode | 68 | fs/ext2/namei.c | static struct buffer_head * ext2_find_entry (struct inode * dir, |
inode | 135 | fs/ext2/namei.c | if (de->inode != 0 && ext2_match (namelen, name, de)) { |
inode | 165 | fs/ext2/namei.c | int ext2_lookup (struct inode * dir, const char * name, int len, |
inode | 166 | fs/ext2/namei.c | struct inode ** result) |
inode | 198 | fs/ext2/namei.c | ino = de->inode; |
inode | 219 | fs/ext2/namei.c | static struct buffer_head * ext2_add_entry (struct inode * dir, |
inode | 275 | fs/ext2/namei.c | de->inode = 0; |
inode | 292 | fs/ext2/namei.c | if (de->inode != 0 && ext2_match (namelen, name, de)) { |
inode | 297 | fs/ext2/namei.c | if ((de->inode == 0 && de->rec_len >= rec_len) || |
inode | 300 | fs/ext2/namei.c | if (de->inode) { |
inode | 308 | fs/ext2/namei.c | de->inode = 0; |
inode | 357 | fs/ext2/namei.c | dir->inode = 0; |
inode | 367 | fs/ext2/namei.c | int ext2_create (struct inode * dir,const char * name, int len, int mode, |
inode | 368 | fs/ext2/namei.c | struct inode ** result) |
inode | 370 | fs/ext2/namei.c | struct inode * inode; |
inode | 378 | fs/ext2/namei.c | inode = ext2_new_inode (dir, mode, &err); |
inode | 379 | fs/ext2/namei.c | if (!inode) { |
inode | 383 | fs/ext2/namei.c | inode->i_op = &ext2_file_inode_operations; |
inode | 384 | fs/ext2/namei.c | inode->i_mode = mode; |
inode | 385 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 388 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 389 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 390 | fs/ext2/namei.c | iput (inode); |
inode | 394 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 396 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 404 | fs/ext2/namei.c | *result = inode; |
inode | 408 | fs/ext2/namei.c | int ext2_mknod (struct inode * dir, const char * name, int len, int mode, |
inode | 411 | fs/ext2/namei.c | struct inode * inode; |
inode | 424 | fs/ext2/namei.c | inode = ext2_new_inode (dir, mode, &err); |
inode | 425 | fs/ext2/namei.c | if (!inode) { |
inode | 429 | fs/ext2/namei.c | inode->i_uid = current->fsuid; |
inode | 430 | fs/ext2/namei.c | inode->i_mode = mode; |
inode | 431 | fs/ext2/namei.c | inode->i_op = NULL; |
inode | 432 | fs/ext2/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 433 | fs/ext2/namei.c | inode->i_op = &ext2_file_inode_operations; |
inode | 434 | fs/ext2/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 435 | fs/ext2/namei.c | inode->i_op = &ext2_dir_inode_operations; |
inode | 437 | fs/ext2/namei.c | inode->i_mode |= S_ISGID; |
inode | 439 | fs/ext2/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 440 | fs/ext2/namei.c | inode->i_op = &ext2_symlink_inode_operations; |
inode | 441 | fs/ext2/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 442 | fs/ext2/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 443 | fs/ext2/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 444 | fs/ext2/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 445 | fs/ext2/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 446 | fs/ext2/namei.c | init_fifo(inode); |
inode | 448 | fs/ext2/namei.c | inode->i_rdev = to_kdev_t(rdev); |
inode | 449 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 452 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 453 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 454 | fs/ext2/namei.c | iput (inode); |
inode | 458 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 460 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 468 | fs/ext2/namei.c | iput (inode); |
inode | 472 | fs/ext2/namei.c | int ext2_mkdir (struct inode * dir, const char * name, int len, int mode) |
inode | 474 | fs/ext2/namei.c | struct inode * inode; |
inode | 491 | fs/ext2/namei.c | inode = ext2_new_inode (dir, S_IFDIR, &err); |
inode | 492 | fs/ext2/namei.c | if (!inode) { |
inode | 496 | fs/ext2/namei.c | inode->i_op = &ext2_dir_inode_operations; |
inode | 497 | fs/ext2/namei.c | inode->i_size = inode->i_sb->s_blocksize; |
inode | 498 | fs/ext2/namei.c | dir_block = ext2_bread (inode, 0, 1, &err); |
inode | 501 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 502 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 503 | fs/ext2/namei.c | iput (inode); |
inode | 506 | fs/ext2/namei.c | inode->i_blocks = inode->i_sb->s_blocksize / 512; |
inode | 508 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 513 | fs/ext2/namei.c | de->inode = dir->i_ino; |
inode | 514 | fs/ext2/namei.c | de->rec_len = inode->i_sb->s_blocksize - EXT2_DIR_REC_LEN(1); |
inode | 517 | fs/ext2/namei.c | inode->i_nlink = 2; |
inode | 520 | fs/ext2/namei.c | inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->fs->umask); |
inode | 522 | fs/ext2/namei.c | inode->i_mode |= S_ISGID; |
inode | 523 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 527 | fs/ext2/namei.c | inode->i_nlink = 0; |
inode | 528 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 529 | fs/ext2/namei.c | iput (inode); |
inode | 532 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 534 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 543 | fs/ext2/namei.c | iput (inode); |
inode | 551 | fs/ext2/namei.c | static int empty_dir (struct inode * inode) |
inode | 559 | fs/ext2/namei.c | sb = inode->i_sb; |
inode | 560 | fs/ext2/namei.c | if (inode->i_size < EXT2_DIR_REC_LEN(1) + EXT2_DIR_REC_LEN(2) || |
inode | 561 | fs/ext2/namei.c | !(bh = ext2_bread (inode, 0, 0, &err))) { |
inode | 562 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "empty_dir", |
inode | 564 | fs/ext2/namei.c | inode->i_ino); |
inode | 569 | fs/ext2/namei.c | if (de->inode != inode->i_ino || !de1->inode || |
inode | 571 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "empty_dir", |
inode | 573 | fs/ext2/namei.c | inode->i_ino); |
inode | 578 | fs/ext2/namei.c | while (offset < inode->i_size ) { |
inode | 581 | fs/ext2/namei.c | bh = ext2_bread (inode, offset >> EXT2_BLOCK_SIZE_BITS(sb), 1, &err); |
inode | 585 | fs/ext2/namei.c | inode->i_ino, offset); |
inode | 591 | fs/ext2/namei.c | if (!ext2_check_dir_entry ("empty_dir", inode, de, bh, |
inode | 596 | fs/ext2/namei.c | if (de->inode) { |
inode | 607 | fs/ext2/namei.c | int ext2_rmdir (struct inode * dir, const char * name, int len) |
inode | 610 | fs/ext2/namei.c | struct inode * inode; |
inode | 617 | fs/ext2/namei.c | inode = NULL; |
inode | 623 | fs/ext2/namei.c | if (!(inode = iget (dir->i_sb, de->inode))) |
inode | 625 | fs/ext2/namei.c | if (inode->i_sb->dq_op) |
inode | 626 | fs/ext2/namei.c | inode->i_sb->dq_op->initialize (inode, -1); |
inode | 627 | fs/ext2/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 629 | fs/ext2/namei.c | if (de->inode != inode->i_ino) { |
inode | 630 | fs/ext2/namei.c | iput(inode); |
inode | 637 | fs/ext2/namei.c | current->fsuid != inode->i_uid && |
inode | 640 | fs/ext2/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 642 | fs/ext2/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 646 | fs/ext2/namei.c | down(&inode->i_sem); |
inode | 647 | fs/ext2/namei.c | if (!empty_dir (inode)) |
inode | 649 | fs/ext2/namei.c | else if (de->inode != inode->i_ino) |
inode | 652 | fs/ext2/namei.c | if (inode->i_count > 1) { |
inode | 660 | fs/ext2/namei.c | inode->i_size = 0; |
inode | 665 | fs/ext2/namei.c | up(&inode->i_sem); |
inode | 673 | fs/ext2/namei.c | if (inode->i_nlink != 2) |
inode | 674 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "ext2_rmdir", |
inode | 676 | fs/ext2/namei.c | inode->i_nlink); |
inode | 677 | fs/ext2/namei.c | inode->i_version = ++event; |
inode | 678 | fs/ext2/namei.c | inode->i_nlink = 0; |
inode | 679 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 681 | fs/ext2/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 685 | fs/ext2/namei.c | iput (inode); |
inode | 690 | fs/ext2/namei.c | int ext2_unlink (struct inode * dir, const char * name, int len) |
inode | 693 | fs/ext2/namei.c | struct inode * inode; |
inode | 701 | fs/ext2/namei.c | inode = NULL; |
inode | 705 | fs/ext2/namei.c | if (!(inode = iget (dir->i_sb, de->inode))) |
inode | 707 | fs/ext2/namei.c | if (inode->i_sb->dq_op) |
inode | 708 | fs/ext2/namei.c | inode->i_sb->dq_op->initialize (inode, -1); |
inode | 710 | fs/ext2/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 712 | fs/ext2/namei.c | if (IS_APPEND(inode) || IS_IMMUTABLE(inode)) |
inode | 714 | fs/ext2/namei.c | if (de->inode != inode->i_ino) { |
inode | 715 | fs/ext2/namei.c | iput(inode); |
inode | 722 | fs/ext2/namei.c | current->fsuid != inode->i_uid && |
inode | 725 | fs/ext2/namei.c | if (!inode->i_nlink) { |
inode | 726 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "ext2_unlink", |
inode | 728 | fs/ext2/namei.c | inode->i_ino, inode->i_nlink); |
inode | 729 | fs/ext2/namei.c | inode->i_nlink = 1; |
inode | 742 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 743 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 744 | fs/ext2/namei.c | inode->i_ctime = dir->i_ctime; |
inode | 748 | fs/ext2/namei.c | iput (inode); |
inode | 753 | fs/ext2/namei.c | int ext2_symlink (struct inode * dir, const char * name, int len, |
inode | 757 | fs/ext2/namei.c | struct inode * inode = NULL; |
inode | 764 | fs/ext2/namei.c | if (!(inode = ext2_new_inode (dir, S_IFLNK, &err))) { |
inode | 768 | fs/ext2/namei.c | inode->i_mode = S_IFLNK | S_IRWXUGO; |
inode | 769 | fs/ext2/namei.c | inode->i_op = &ext2_symlink_inode_operations; |
inode | 770 | fs/ext2/namei.c | for (l = 0; l < inode->i_sb->s_blocksize - 1 && |
inode | 773 | fs/ext2/namei.c | if (l >= sizeof (inode->u.ext2_i.i_data)) { |
inode | 777 | fs/ext2/namei.c | name_block = ext2_bread (inode, 0, 1, &err); |
inode | 780 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 781 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 782 | fs/ext2/namei.c | iput (inode); |
inode | 787 | fs/ext2/namei.c | link = (char *) inode->u.ext2_i.i_data; |
inode | 793 | fs/ext2/namei.c | while (i < inode->i_sb->s_blocksize - 1 && (c = *(symname++))) |
inode | 800 | fs/ext2/namei.c | inode->i_size = i; |
inode | 801 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 805 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 806 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 807 | fs/ext2/namei.c | iput (inode); |
inode | 814 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 815 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 816 | fs/ext2/namei.c | iput (inode); |
inode | 820 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 822 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 830 | fs/ext2/namei.c | iput (inode); |
inode | 834 | fs/ext2/namei.c | int ext2_link (struct inode * oldinode, struct inode * dir, |
inode | 869 | fs/ext2/namei.c | de->inode = oldinode->i_ino; |
inode | 871 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 886 | fs/ext2/namei.c | static int subdir (struct inode * new_inode, struct inode * old_inode) |
inode | 912 | fs/ext2/namei.c | ((struct ext2_dir_entry *) buffer)->rec_len))->inode |
inode | 929 | fs/ext2/namei.c | static int do_ext2_rename (struct inode * old_dir, const char * old_name, |
inode | 930 | fs/ext2/namei.c | int old_len, struct inode * new_dir, |
inode | 933 | fs/ext2/namei.c | struct inode * old_inode, * new_inode; |
inode | 959 | fs/ext2/namei.c | old_inode = __iget (old_dir->i_sb, old_de->inode, 0); /* don't cross mnt-points */ |
inode | 971 | fs/ext2/namei.c | new_inode = __iget (new_dir->i_sb, new_de->inode, 0); /* no mntp cross */ |
inode | 1028 | fs/ext2/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 1030 | fs/ext2/namei.c | if (new_de->inode && !new_inode) |
inode | 1032 | fs/ext2/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 1037 | fs/ext2/namei.c | new_de->inode = old_inode->i_ino; |
inode | 1038 | fs/ext2/namei.c | dcache_add(new_dir, new_de->name, new_de->name_len, new_de->inode); |
inode | 1101 | fs/ext2/namei.c | int ext2_rename (struct inode * old_dir, const char * old_name, int old_len, |
inode | 1102 | fs/ext2/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 26 | fs/ext2/symlink.c | static int ext2_readlink (struct inode *, char *, int); |
inode | 27 | fs/ext2/symlink.c | static int ext2_follow_link (struct inode *, struct inode *, int, int, |
inode | 28 | fs/ext2/symlink.c | struct inode **); |
inode | 54 | fs/ext2/symlink.c | static int ext2_follow_link(struct inode * dir, struct inode * inode, |
inode | 55 | fs/ext2/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 66 | fs/ext2/symlink.c | if (!inode) { |
inode | 70 | fs/ext2/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 72 | fs/ext2/symlink.c | *res_inode = inode; |
inode | 77 | fs/ext2/symlink.c | iput (inode); |
inode | 80 | fs/ext2/symlink.c | if (inode->i_blocks) { |
inode | 81 | fs/ext2/symlink.c | if (!(bh = ext2_bread (inode, 0, 0, &error))) { |
inode | 83 | fs/ext2/symlink.c | iput (inode); |
inode | 88 | fs/ext2/symlink.c | link = (char *) inode->u.ext2_i.i_data; |
inode | 89 | fs/ext2/symlink.c | if (!IS_RDONLY(inode)) { |
inode | 90 | fs/ext2/symlink.c | inode->i_atime = CURRENT_TIME; |
inode | 91 | fs/ext2/symlink.c | inode->i_dirt = 1; |
inode | 96 | fs/ext2/symlink.c | iput (inode); |
inode | 102 | fs/ext2/symlink.c | static int ext2_readlink (struct inode * inode, char * buffer, int buflen) |
inode | 109 | fs/ext2/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 110 | fs/ext2/symlink.c | iput (inode); |
inode | 113 | fs/ext2/symlink.c | if (buflen > inode->i_sb->s_blocksize - 1) |
inode | 114 | fs/ext2/symlink.c | buflen = inode->i_sb->s_blocksize - 1; |
inode | 115 | fs/ext2/symlink.c | if (inode->i_blocks) { |
inode | 116 | fs/ext2/symlink.c | bh = ext2_bread (inode, 0, 0, &err); |
inode | 118 | fs/ext2/symlink.c | iput (inode); |
inode | 124 | fs/ext2/symlink.c | link = (char *) inode->u.ext2_i.i_data; |
inode | 130 | fs/ext2/symlink.c | if (!IS_RDONLY(inode)) { |
inode | 131 | fs/ext2/symlink.c | inode->i_atime = CURRENT_TIME; |
inode | 132 | fs/ext2/symlink.c | inode->i_dirt = 1; |
inode | 134 | fs/ext2/symlink.c | iput (inode); |
inode | 59 | fs/ext2/truncate.c | static int trunc_direct (struct inode * inode) |
inode | 67 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 68 | fs/ext2/truncate.c | #define DIRECT_BLOCK ((inode->i_size + inode->i_sb->s_blocksize - 1) / \ |
inode | 69 | fs/ext2/truncate.c | inode->i_sb->s_blocksize) |
inode | 74 | fs/ext2/truncate.c | p = inode->u.ext2_i.i_data + i; |
inode | 78 | fs/ext2/truncate.c | bh = get_hash_table (inode->i_dev, tmp, |
inode | 79 | fs/ext2/truncate.c | inode->i_sb->s_blocksize); |
inode | 90 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 91 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 99 | fs/ext2/truncate.c | ext2_free_blocks (inode, block_to_free, free_count); |
inode | 106 | fs/ext2/truncate.c | ext2_free_blocks (inode, block_to_free, free_count); |
inode | 110 | fs/ext2/truncate.c | static int trunc_indirect (struct inode * inode, int offset, u32 * p) |
inode | 119 | fs/ext2/truncate.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 120 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 127 | fs/ext2/truncate.c | ind_bh = bread (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 146 | fs/ext2/truncate.c | bh = get_hash_table (inode->i_dev, tmp, |
inode | 147 | fs/ext2/truncate.c | inode->i_sb->s_blocksize); |
inode | 166 | fs/ext2/truncate.c | ext2_free_blocks (inode, block_to_free, free_count); |
inode | 171 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 172 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 175 | fs/ext2/truncate.c | ext2_free_blocks (inode, block_to_free, free_count); |
inode | 186 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 187 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 188 | fs/ext2/truncate.c | ext2_free_blocks (inode, tmp, 1); |
inode | 190 | fs/ext2/truncate.c | if (IS_SYNC(inode) && buffer_dirty(ind_bh)) { |
inode | 198 | fs/ext2/truncate.c | static int trunc_dindirect (struct inode * inode, int offset, |
inode | 205 | fs/ext2/truncate.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 206 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 213 | fs/ext2/truncate.c | dind_bh = bread (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 232 | fs/ext2/truncate.c | retry |= trunc_indirect (inode, offset + (i * addr_per_block), |
inode | 246 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 247 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 248 | fs/ext2/truncate.c | ext2_free_blocks (inode, tmp, 1); |
inode | 250 | fs/ext2/truncate.c | if (IS_SYNC(inode) && buffer_dirty(dind_bh)) { |
inode | 258 | fs/ext2/truncate.c | static int trunc_tindirect (struct inode * inode) |
inode | 264 | fs/ext2/truncate.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 265 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 271 | fs/ext2/truncate.c | p = inode->u.ext2_i.i_data + EXT2_TIND_BLOCK; |
inode | 274 | fs/ext2/truncate.c | tind_bh = bread (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 290 | fs/ext2/truncate.c | retry |= trunc_dindirect(inode, EXT2_NDIR_BLOCKS + |
inode | 305 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 306 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 307 | fs/ext2/truncate.c | ext2_free_blocks (inode, tmp, 1); |
inode | 309 | fs/ext2/truncate.c | if (IS_SYNC(inode) && buffer_dirty(tind_bh)) { |
inode | 317 | fs/ext2/truncate.c | void ext2_truncate (struct inode * inode) |
inode | 324 | fs/ext2/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 325 | fs/ext2/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 327 | fs/ext2/truncate.c | if (IS_APPEND(inode) || IS_IMMUTABLE(inode)) |
inode | 329 | fs/ext2/truncate.c | ext2_discard_prealloc(inode); |
inode | 331 | fs/ext2/truncate.c | retry = trunc_direct(inode); |
inode | 332 | fs/ext2/truncate.c | retry |= trunc_indirect (inode, EXT2_IND_BLOCK, |
inode | 333 | fs/ext2/truncate.c | (u32 *) &inode->u.ext2_i.i_data[EXT2_IND_BLOCK]); |
inode | 334 | fs/ext2/truncate.c | retry |= trunc_dindirect (inode, EXT2_IND_BLOCK + |
inode | 335 | fs/ext2/truncate.c | EXT2_ADDR_PER_BLOCK(inode->i_sb), |
inode | 336 | fs/ext2/truncate.c | (u32 *) &inode->u.ext2_i.i_data[EXT2_DIND_BLOCK]); |
inode | 337 | fs/ext2/truncate.c | retry |= trunc_tindirect (inode); |
inode | 340 | fs/ext2/truncate.c | if (IS_SYNC(inode) && inode->i_dirt) |
inode | 341 | fs/ext2/truncate.c | ext2_sync_inode (inode); |
inode | 351 | fs/ext2/truncate.c | offset = inode->i_size & (inode->i_sb->s_blocksize - 1); |
inode | 353 | fs/ext2/truncate.c | bh = ext2_bread (inode, |
inode | 354 | fs/ext2/truncate.c | inode->i_size >> EXT2_BLOCK_SIZE_BITS(inode->i_sb), |
inode | 358 | fs/ext2/truncate.c | inode->i_sb->s_blocksize - offset); |
inode | 363 | fs/ext2/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 364 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 120 | fs/fat/cache.c | void cache_lookup(struct inode *inode,int cluster,int *f_clu,int *d_clu) |
inode | 125 | fs/fat/cache.c | printk("cache lookup: <%s,%d> %d (%d,%d) -> ", kdevname(inode->i_dev), |
inode | 126 | fs/fat/cache.c | inode->i_ino, cluster, *f_clu, *d_clu); |
inode | 129 | fs/fat/cache.c | if (inode->i_dev == walk->device |
inode | 130 | fs/fat/cache.c | && walk->ino == inode->i_ino |
inode | 161 | fs/fat/cache.c | void cache_add(struct inode *inode,int f_clu,int d_clu) |
inode | 166 | fs/fat/cache.c | printk("cache add: <%s,%d> %d (%d)\n", kdevname(inode->i_dev), |
inode | 167 | fs/fat/cache.c | inode->i_ino, f_clu, d_clu); |
inode | 171 | fs/fat/cache.c | if (inode->i_dev == walk->device |
inode | 172 | fs/fat/cache.c | && walk->ino == inode->i_ino |
inode | 176 | fs/fat/cache.c | fat_cache_inval_inode(inode); |
inode | 189 | fs/fat/cache.c | walk->device = inode->i_dev; |
inode | 190 | fs/fat/cache.c | walk->ino = inode->i_ino; |
inode | 205 | fs/fat/cache.c | void fat_cache_inval_inode(struct inode *inode) |
inode | 210 | fs/fat/cache.c | if (walk->device == inode->i_dev |
inode | 211 | fs/fat/cache.c | && walk->ino == inode->i_ino) |
inode | 226 | fs/fat/cache.c | int get_cluster(struct inode *inode,int cluster) |
inode | 230 | fs/fat/cache.c | if (!(nr = MSDOS_I(inode)->i_start)) return 0; |
inode | 233 | fs/fat/cache.c | for (cache_lookup(inode,cluster,&count,&nr); count < cluster; |
inode | 235 | fs/fat/cache.c | if ((nr = fat_access(inode->i_sb,nr,-1)) == -1) return 0; |
inode | 238 | fs/fat/cache.c | cache_add(inode,cluster,nr); |
inode | 243 | fs/fat/cache.c | int fat_smap(struct inode *inode,int sector) |
inode | 248 | fs/fat/cache.c | sb = MSDOS_SB(inode->i_sb); |
inode | 249 | fs/fat/cache.c | if (inode->i_ino == MSDOS_ROOT_INO || (S_ISDIR(inode->i_mode) && |
inode | 250 | fs/fat/cache.c | !MSDOS_I(inode)->i_start)) { |
inode | 256 | fs/fat/cache.c | if (!(cluster = get_cluster(inode,cluster))) return 0; |
inode | 264 | fs/fat/cache.c | int fat_free(struct inode *inode,int skip) |
inode | 268 | fs/fat/cache.c | if (!(nr = MSDOS_I(inode)->i_start)) return 0; |
inode | 272 | fs/fat/cache.c | if ((nr = fat_access(inode->i_sb,nr,-1)) == -1) return 0; |
inode | 279 | fs/fat/cache.c | fat_access(inode->i_sb,last,MSDOS_SB(inode->i_sb)->fat_bits == |
inode | 282 | fs/fat/cache.c | MSDOS_I(inode)->i_start = 0; |
inode | 283 | fs/fat/cache.c | inode->i_dirt = 1; |
inode | 285 | fs/fat/cache.c | lock_fat(inode->i_sb); |
inode | 287 | fs/fat/cache.c | if (!(nr = fat_access(inode->i_sb,nr,0))) { |
inode | 288 | fs/fat/cache.c | fat_fs_panic(inode->i_sb,"fat_free: deleting beyond EOF"); |
inode | 291 | fs/fat/cache.c | if (MSDOS_SB(inode->i_sb)->free_clusters != -1) |
inode | 292 | fs/fat/cache.c | MSDOS_SB(inode->i_sb)->free_clusters++; |
inode | 293 | fs/fat/cache.c | inode->i_blocks -= MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 295 | fs/fat/cache.c | unlock_fat(inode->i_sb); |
inode | 296 | fs/fat/cache.c | fat_cache_inval_inode(inode); |
inode | 32 | fs/fat/dir.c | static int fat_dir_read(struct inode * inode,struct file * filp, char * buf,int count) |
inode | 95 | fs/fat/dir.c | struct inode *inode, |
inode | 104 | fs/fat/dir.c | struct super_block *sb = inode->i_sb; |
inode | 119 | fs/fat/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 122 | fs/fat/dir.c | if (inode->i_ino == MSDOS_ROOT_INO) { |
inode | 138 | fs/fat/dir.c | ino = fat_get_entry(inode,&filp->f_pos,&bh,&de); |
inode | 201 | fs/fat/dir.c | ino = fat_get_entry(inode,&filp->f_pos,&bh,&de); |
inode | 257 | fs/fat/dir.c | ino = inode->i_ino; |
inode | 259 | fs/fat/dir.c | ino = fat_parent_ino(inode,0); |
inode | 262 | fs/fat/dir.c | dcache_add(inode, bufname, i+dotoffset, ino); |
inode | 278 | fs/fat/dir.c | dcache_add(inode, longname, long_len, ino); |
inode | 296 | fs/fat/dir.c | ino = fat_get_entry(inode,&filp->f_pos,&bh,&de); |
inode | 320 | fs/fat/dir.c | struct inode *inode, |
inode | 325 | fs/fat/dir.c | return fat_readdirx(inode, filp, dirent, fat_filldir, filldir, |
inode | 380 | fs/fat/dir.c | int fat_dir_ioctl(struct inode * inode, struct file * filp, |
inode | 393 | fs/fat/dir.c | return fat_readdirx(inode,filp,(void *)arg, |
inode | 399 | fs/fat/dir.c | return fat_readdirx(inode,filp,(void *)arg, |
inode | 124 | fs/fat/file.c | struct inode *inode, |
inode | 128 | fs/fat/file.c | struct super_block *sb = inode->i_sb; |
inode | 134 | fs/fat/file.c | int sector = fat_smap(inode,pre->file_sector); |
inode | 139 | fs/fat/file.c | bh = getblk(inode->i_dev,sector,SECTOR_SIZE); |
inode | 155 | fs/fat/file.c | struct inode *inode, |
inode | 160 | fs/fat/file.c | struct super_block *sb = inode->i_sb; |
inode | 168 | fs/fat/file.c | if (!inode) { |
inode | 173 | fs/fat/file.c | if (!S_ISREG(inode->i_mode) && !S_ISLNK(inode->i_mode)) { |
inode | 174 | fs/fat/file.c | printk("fat_file_read: mode = %07o\n",inode->i_mode); |
inode | 177 | fs/fat/file.c | if (filp->f_pos >= inode->i_size || count <= 0) return 0; |
inode | 187 | fs/fat/file.c | PRINTK (("#### ino %ld pos %ld size %ld count %d\n",inode->i_ino,filp->f_pos,inode->i_size,count)); |
inode | 198 | fs/fat/file.c | if (filp->f_reada || !MSDOS_I(inode)->i_binary){ |
inode | 202 | fs/fat/file.c | int ahead = read_ahead[MAJOR(inode->i_dev)]; |
inode | 209 | fs/fat/file.c | fat_prefetch (inode,&pre,to_reada); |
inode | 212 | fs/fat/file.c | PRINTK (("count %d ahead %d nblist %d\n",count,read_ahead[MAJOR(inode->i_dev)],pre.nblist)); |
inode | 213 | fs/fat/file.c | while ((left_in_file = inode->i_size - filp->f_pos) > 0 |
inode | 225 | fs/fat/file.c | fat_prefetch (inode,&pre,MSDOS_PREFETCH/2); |
inode | 238 | fs/fat/file.c | if (MSDOS_I(inode)->i_binary) { |
inode | 248 | fs/fat/file.c | filp->f_pos = inode->i_size; |
inode | 260 | fs/fat/file.c | if (!IS_RDONLY(inode)) inode->i_atime = CURRENT_TIME; |
inode | 269 | fs/fat/file.c | struct inode *inode, |
inode | 274 | fs/fat/file.c | struct super_block *sb = inode->i_sb; |
inode | 280 | fs/fat/file.c | int binary_mode = MSDOS_I(inode)->i_binary; |
inode | 282 | fs/fat/file.c | if (!inode) { |
inode | 287 | fs/fat/file.c | if (!S_ISREG(inode->i_mode) && !S_ISLNK(inode->i_mode)) { |
inode | 288 | fs/fat/file.c | printk("fat_file_write: mode = %07o\n",inode->i_mode); |
inode | 292 | fs/fat/file.c | if (IS_IMMUTABLE(inode)) return -EPERM; |
inode | 297 | fs/fat/file.c | if (filp->f_flags & O_APPEND) filp->f_pos = inode->i_size; |
inode | 301 | fs/fat/file.c | while (!(sector = fat_smap(inode,filp->f_pos >> SECTOR_BITS))) |
inode | 302 | fs/fat/file.c | if ((error = fat_add_cluster(inode)) < 0) break; |
inode | 304 | fs/fat/file.c | fat_truncate(inode); |
inode | 312 | fs/fat/file.c | || filp->f_pos + size >= inode->i_size)){ |
inode | 316 | fs/fat/file.c | if (!(bh = getblk(inode->i_dev,sector,SECTOR_SIZE))){ |
inode | 320 | fs/fat/file.c | }else if (!(bh = bread(inode->i_dev,sector,SECTOR_SIZE))) { |
inode | 349 | fs/fat/file.c | update_vm_cache(inode, filp->f_pos, bh->b_data + (filp->f_pos & (SECTOR_SIZE-1)), written); |
inode | 351 | fs/fat/file.c | if (filp->f_pos > inode->i_size) { |
inode | 352 | fs/fat/file.c | inode->i_size = filp->f_pos; |
inode | 353 | fs/fat/file.c | inode->i_dirt = 1; |
inode | 361 | fs/fat/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 362 | fs/fat/file.c | MSDOS_I(inode)->i_attrs |= ATTR_ARCH; |
inode | 363 | fs/fat/file.c | inode->i_dirt = 1; |
inode | 367 | fs/fat/file.c | void fat_truncate(struct inode *inode) |
inode | 372 | fs/fat/file.c | if (IS_IMMUTABLE(inode)) return /* -EPERM */; |
inode | 373 | fs/fat/file.c | cluster = SECTOR_SIZE*MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 374 | fs/fat/file.c | (void) fat_free(inode,(inode->i_size+(cluster-1))/cluster); |
inode | 375 | fs/fat/file.c | MSDOS_I(inode)->i_attrs |= ATTR_ARCH; |
inode | 376 | fs/fat/file.c | inode->i_dirt = 1; |
inode | 29 | fs/fat/inode.c | void fat_put_inode(struct inode *inode) |
inode | 31 | fs/fat/inode.c | struct inode *depend, *linked; |
inode | 34 | fs/fat/inode.c | depend = MSDOS_I(inode)->i_depend; |
inode | 35 | fs/fat/inode.c | linked = MSDOS_I(inode)->i_linked; |
inode | 36 | fs/fat/inode.c | sb = inode->i_sb; |
inode | 37 | fs/fat/inode.c | if (inode->i_nlink) { |
inode | 43 | fs/fat/inode.c | MSDOS_I(inode)->i_linked = NULL; |
inode | 45 | fs/fat/inode.c | if (MSDOS_I(inode)->i_busy) fat_cache_inval_inode(inode); |
inode | 48 | fs/fat/inode.c | inode->i_size = 0; |
inode | 49 | fs/fat/inode.c | fat_truncate(inode); |
inode | 50 | fs/fat/inode.c | clear_inode(inode); |
inode | 52 | fs/fat/inode.c | if (MSDOS_I(depend)->i_old != inode) { |
inode | 54 | fs/fat/inode.c | depend, inode, MSDOS_I(depend)->i_old); |
inode | 62 | fs/fat/inode.c | if (MSDOS_I(linked)->i_oldlink != inode) { |
inode | 64 | fs/fat/inode.c | linked, inode, MSDOS_I(linked)->i_oldlink); |
inode | 354 | fs/fat/inode.c | int fat_bmap(struct inode *inode,int block) |
inode | 359 | fs/fat/inode.c | sb = MSDOS_SB(inode->i_sb); |
inode | 360 | fs/fat/inode.c | if (inode->i_ino == MSDOS_ROOT_INO) { |
inode | 365 | fs/fat/inode.c | if (!(cluster = get_cluster(inode,cluster))) return 0; |
inode | 379 | fs/fat/inode.c | void fat_read_inode(struct inode *inode, struct inode_operations *fs_dir_inode_ops) |
inode | 381 | fs/fat/inode.c | struct super_block *sb = inode->i_sb; |
inode | 387 | fs/fat/inode.c | MSDOS_I(inode)->i_busy = 0; |
inode | 388 | fs/fat/inode.c | MSDOS_I(inode)->i_depend = MSDOS_I(inode)->i_old = NULL; |
inode | 389 | fs/fat/inode.c | MSDOS_I(inode)->i_linked = MSDOS_I(inode)->i_oldlink = NULL; |
inode | 390 | fs/fat/inode.c | MSDOS_I(inode)->i_binary = 1; |
inode | 391 | fs/fat/inode.c | inode->i_uid = MSDOS_SB(inode->i_sb)->options.fs_uid; |
inode | 392 | fs/fat/inode.c | inode->i_gid = MSDOS_SB(inode->i_sb)->options.fs_gid; |
inode | 393 | fs/fat/inode.c | inode->i_version = ++event; |
inode | 394 | fs/fat/inode.c | if (inode->i_ino == MSDOS_ROOT_INO) { |
inode | 395 | fs/fat/inode.c | inode->i_mode = (S_IRWXUGO & ~MSDOS_SB(inode->i_sb)->options.fs_umask) | |
inode | 397 | fs/fat/inode.c | inode->i_op = fs_dir_inode_ops; |
inode | 398 | fs/fat/inode.c | inode->i_nlink = fat_subdirs(inode)+2; |
inode | 400 | fs/fat/inode.c | inode->i_size = MSDOS_SB(inode->i_sb)->dir_entries* |
inode | 402 | fs/fat/inode.c | inode->i_blksize = MSDOS_SB(inode->i_sb)->cluster_size* |
inode | 404 | fs/fat/inode.c | inode->i_blocks = (inode->i_size+inode->i_blksize-1)/ |
inode | 405 | fs/fat/inode.c | inode->i_blksize*MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 406 | fs/fat/inode.c | MSDOS_I(inode)->i_start = 0; |
inode | 407 | fs/fat/inode.c | MSDOS_I(inode)->i_attrs = 0; |
inode | 408 | fs/fat/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = 0; |
inode | 411 | fs/fat/inode.c | if (!(bh = bread(inode->i_dev,inode->i_ino >> MSDOS_DPB_BITS, |
inode | 414 | fs/fat/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 418 | fs/fat/inode.c | [inode->i_ino & (MSDOS_DPB-1)]; |
inode | 420 | fs/fat/inode.c | inode->i_mode = MSDOS_MKMODE(raw_entry->attr,S_IRWXUGO & |
inode | 421 | fs/fat/inode.c | ~MSDOS_SB(inode->i_sb)->options.fs_umask) | S_IFDIR; |
inode | 422 | fs/fat/inode.c | inode->i_op = fs_dir_inode_ops; |
inode | 424 | fs/fat/inode.c | MSDOS_I(inode)->i_start = CF_LE_W(raw_entry->start); |
inode | 425 | fs/fat/inode.c | inode->i_nlink = fat_subdirs(inode); |
inode | 428 | fs/fat/inode.c | if (!inode->i_nlink) { |
inode | 429 | fs/fat/inode.c | printk("directory %d: i_nlink == 0\n",inode->i_ino); |
inode | 430 | fs/fat/inode.c | inode->i_nlink = 1; |
inode | 433 | fs/fat/inode.c | inode->i_size = 0; |
inode | 436 | fs/fat/inode.c | inode->i_size += SECTOR_SIZE*MSDOS_SB(inode-> |
inode | 438 | fs/fat/inode.c | if (!(nr = fat_access(inode->i_sb,nr,-1))) { |
inode | 440 | fs/fat/inode.c | inode->i_ino); |
inode | 445 | fs/fat/inode.c | inode->i_mode = MSDOS_MKMODE(raw_entry->attr, |
inode | 446 | fs/fat/inode.c | ((IS_NOEXEC(inode) || |
inode | 447 | fs/fat/inode.c | (MSDOS_SB(inode->i_sb)->options.showexec && |
inode | 450 | fs/fat/inode.c | & ~MSDOS_SB(inode->i_sb)->options.fs_umask) | S_IFREG; |
inode | 451 | fs/fat/inode.c | inode->i_op = (sb->s_blocksize == 1024) |
inode | 454 | fs/fat/inode.c | MSDOS_I(inode)->i_start = CF_LE_W(raw_entry->start); |
inode | 455 | fs/fat/inode.c | inode->i_nlink = 1; |
inode | 456 | fs/fat/inode.c | inode->i_size = CF_LE_L(raw_entry->size); |
inode | 459 | fs/fat/inode.c | if (MSDOS_SB(inode->i_sb)->options.sys_immutable) |
inode | 460 | fs/fat/inode.c | inode->i_flags |= S_IMMUTABLE; |
inode | 461 | fs/fat/inode.c | MSDOS_I(inode)->i_binary = is_binary(MSDOS_SB(inode->i_sb)->options.conversion, |
inode | 463 | fs/fat/inode.c | MSDOS_I(inode)->i_attrs = raw_entry->attr & ATTR_UNUSED; |
inode | 465 | fs/fat/inode.c | inode->i_blksize = MSDOS_SB(inode->i_sb)->cluster_size*SECTOR_SIZE; |
inode | 466 | fs/fat/inode.c | inode->i_blocks = (inode->i_size+inode->i_blksize-1)/ |
inode | 467 | fs/fat/inode.c | inode->i_blksize*MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 468 | fs/fat/inode.c | inode->i_mtime = inode->i_atime = |
inode | 470 | fs/fat/inode.c | inode->i_ctime = |
inode | 471 | fs/fat/inode.c | MSDOS_SB(inode->i_sb)->options.isvfat |
inode | 473 | fs/fat/inode.c | : inode->i_mtime; |
inode | 478 | fs/fat/inode.c | void fat_write_inode(struct inode *inode) |
inode | 480 | fs/fat/inode.c | struct super_block *sb = inode->i_sb; |
inode | 483 | fs/fat/inode.c | struct inode *linked; |
inode | 485 | fs/fat/inode.c | linked = MSDOS_I(inode)->i_linked; |
inode | 487 | fs/fat/inode.c | if (MSDOS_I(linked)->i_oldlink != inode) { |
inode | 489 | fs/fat/inode.c | linked, inode, MSDOS_I(linked)->i_oldlink); |
inode | 494 | fs/fat/inode.c | linked->i_mode = inode->i_mode; |
inode | 495 | fs/fat/inode.c | linked->i_uid = inode->i_uid; |
inode | 496 | fs/fat/inode.c | linked->i_gid = inode->i_gid; |
inode | 497 | fs/fat/inode.c | linked->i_size = inode->i_size; |
inode | 498 | fs/fat/inode.c | linked->i_atime = inode->i_atime; |
inode | 499 | fs/fat/inode.c | linked->i_mtime = inode->i_mtime; |
inode | 500 | fs/fat/inode.c | linked->i_ctime = inode->i_ctime; |
inode | 501 | fs/fat/inode.c | linked->i_blocks = inode->i_blocks; |
inode | 502 | fs/fat/inode.c | linked->i_atime = inode->i_atime; |
inode | 503 | fs/fat/inode.c | MSDOS_I(linked)->i_attrs = MSDOS_I(inode)->i_attrs; |
inode | 507 | fs/fat/inode.c | inode->i_dirt = 0; |
inode | 508 | fs/fat/inode.c | if (inode->i_ino == MSDOS_ROOT_INO || !inode->i_nlink) return; |
inode | 509 | fs/fat/inode.c | if (!(bh = bread(inode->i_dev,inode->i_ino >> MSDOS_DPB_BITS, |
inode | 512 | fs/fat/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 516 | fs/fat/inode.c | [inode->i_ino & (MSDOS_DPB-1)]; |
inode | 517 | fs/fat/inode.c | if (S_ISDIR(inode->i_mode)) { |
inode | 523 | fs/fat/inode.c | raw_entry->size = CT_LE_L(inode->i_size); |
inode | 525 | fs/fat/inode.c | raw_entry->attr |= MSDOS_MKATTR(inode->i_mode) | |
inode | 526 | fs/fat/inode.c | MSDOS_I(inode)->i_attrs; |
inode | 527 | fs/fat/inode.c | raw_entry->start = CT_LE_W(MSDOS_I(inode)->i_start); |
inode | 528 | fs/fat/inode.c | fat_date_unix2dos(inode->i_mtime,&raw_entry->time,&raw_entry->date); |
inode | 532 | fs/fat/inode.c | fat_date_unix2dos(inode->i_ctime,&raw_entry->ctime,&raw_entry->cdate); |
inode | 541 | fs/fat/inode.c | int fat_notify_change(struct inode * inode,struct iattr * attr) |
inode | 545 | fs/fat/inode.c | error = inode_change_ok(inode, attr); |
inode | 547 | fs/fat/inode.c | return MSDOS_SB(inode->i_sb)->options.quiet ? 0 : error; |
inode | 550 | fs/fat/inode.c | (attr->ia_uid != MSDOS_SB(inode->i_sb)->options.fs_uid)) || |
inode | 552 | fs/fat/inode.c | (attr->ia_gid != MSDOS_SB(inode->i_sb)->options.fs_gid)) || |
inode | 558 | fs/fat/inode.c | return MSDOS_SB(inode->i_sb)->options.quiet ? 0 : error; |
inode | 560 | fs/fat/inode.c | inode_setattr(inode, attr); |
inode | 562 | fs/fat/inode.c | if (IS_NOEXEC(inode) && !S_ISDIR(inode->i_mode)) |
inode | 563 | fs/fat/inode.c | inode->i_mode &= S_IFMT | S_IRUGO | S_IWUGO; |
inode | 565 | fs/fat/inode.c | inode->i_mode |= S_IXUGO; |
inode | 567 | fs/fat/inode.c | inode->i_mode = ((inode->i_mode & S_IFMT) | ((((inode->i_mode & S_IRWXU |
inode | 568 | fs/fat/inode.c | & ~MSDOS_SB(inode->i_sb)->options.fs_umask) | S_IRUSR) >> 6)*S_IXUGO)) & |
inode | 569 | fs/fat/inode.c | ~MSDOS_SB(inode->i_sb)->options.fs_umask; |
inode | 116 | fs/fat/misc.c | int fat_add_cluster(struct inode *inode) |
inode | 118 | fs/fat/misc.c | struct super_block *sb = inode->i_sb; |
inode | 121 | fs/fat/misc.c | int cluster_size = MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 123 | fs/fat/misc.c | if (inode->i_ino == MSDOS_ROOT_INO) return -ENOSPC; |
inode | 124 | fs/fat/misc.c | if (!MSDOS_SB(inode->i_sb)->free_clusters) return -ENOSPC; |
inode | 125 | fs/fat/misc.c | lock_fat(inode->i_sb); |
inode | 126 | fs/fat/misc.c | limit = MSDOS_SB(inode->i_sb)->clusters; |
inode | 129 | fs/fat/misc.c | nr = ((count+MSDOS_SB(inode->i_sb)->prev_free) % limit)+2; |
inode | 130 | fs/fat/misc.c | if (fat_access(inode->i_sb,nr,-1) == 0) break; |
inode | 136 | fs/fat/misc.c | MSDOS_SB(inode->i_sb)->prev_free = (count+MSDOS_SB(inode->i_sb)-> |
inode | 139 | fs/fat/misc.c | MSDOS_SB(inode->i_sb)->free_clusters = 0; |
inode | 140 | fs/fat/misc.c | unlock_fat(inode->i_sb); |
inode | 143 | fs/fat/misc.c | fat_access(inode->i_sb,nr,MSDOS_SB(inode->i_sb)->fat_bits == 12 ? |
inode | 145 | fs/fat/misc.c | if (MSDOS_SB(inode->i_sb)->free_clusters != -1) |
inode | 146 | fs/fat/misc.c | MSDOS_SB(inode->i_sb)->free_clusters--; |
inode | 147 | fs/fat/misc.c | unlock_fat(inode->i_sb); |
inode | 149 | fs/fat/misc.c | printk("set to %x\n",fat_access(inode->i_sb,nr,-1)); |
inode | 163 | fs/fat/misc.c | if ((curr = MSDOS_I(inode)->i_start) != 0) { |
inode | 164 | fs/fat/misc.c | cache_lookup(inode,INT_MAX,&last,&curr); |
inode | 169 | fs/fat/misc.c | if (!(curr = fat_access(inode->i_sb, |
inode | 171 | fs/fat/misc.c | fat_fs_panic(inode->i_sb,"File without EOF"); |
inode | 180 | fs/fat/misc.c | if (last) fat_access(inode->i_sb,last,nr); |
inode | 182 | fs/fat/misc.c | MSDOS_I(inode)->i_start = nr; |
inode | 183 | fs/fat/misc.c | inode->i_dirt = 1; |
inode | 186 | fs/fat/misc.c | if (last) printk("next set to %d\n",fat_access(inode->i_sb,last,-1)); |
inode | 188 | fs/fat/misc.c | sector = MSDOS_SB(inode->i_sb)->data_start+(nr-2)*cluster_size; |
inode | 194 | fs/fat/misc.c | if (!(bh = getblk(inode->i_dev,sector,SECTOR_SIZE))) |
inode | 203 | fs/fat/misc.c | if (file_cluster != inode->i_blocks/cluster_size){ |
inode | 205 | fs/fat/misc.c | ,file_cluster,inode->i_blocks/cluster_size); |
inode | 207 | fs/fat/misc.c | cache_add(inode,file_cluster,nr); |
inode | 209 | fs/fat/misc.c | inode->i_blocks += cluster_size; |
inode | 210 | fs/fat/misc.c | if (S_ISDIR(inode->i_mode)) { |
inode | 211 | fs/fat/misc.c | if (inode->i_size & (SECTOR_SIZE-1)) { |
inode | 212 | fs/fat/misc.c | fat_fs_panic(inode->i_sb,"Odd directory size"); |
inode | 213 | fs/fat/misc.c | inode->i_size = (inode->i_size+SECTOR_SIZE) & |
inode | 216 | fs/fat/misc.c | inode->i_size += SECTOR_SIZE*cluster_size; |
inode | 218 | fs/fat/misc.c | printk("size is %d now (%x)\n",inode->i_size,inode); |
inode | 220 | fs/fat/misc.c | inode->i_dirt = 1; |
inode | 283 | fs/fat/misc.c | int fat_get_entry(struct inode *dir, loff_t *pos,struct buffer_head **bh, |
inode | 350 | fs/fat/misc.c | inode = iget(sb,sector*MSDOS_DPS+entry); \ |
inode | 351 | fs/fat/misc.c | if (inode) { \ |
inode | 353 | fs/fat/misc.c | done = !MSDOS_I(inode)->i_busy; \ |
inode | 354 | fs/fat/misc.c | iput(inode); \ |
inode | 372 | fs/fat/misc.c | struct inode *inode; |
inode | 485 | fs/fat/misc.c | int fat_parent_ino(struct inode *dir,int locked) |
inode | 521 | fs/fat/misc.c | int fat_subdirs(struct inode *dir) |
inode | 542 | fs/fat/misc.c | int fat_scan(struct inode *dir,const char *name,struct buffer_head **res_bh, |
inode | 32 | fs/fat/mmap.c | struct inode * inode = area->vm_inode; |
inode | 45 | fs/fat/mmap.c | gap = inode->i_size - pos; |
inode | 62 | fs/fat/mmap.c | cur_read = fat_file_read (inode,&filp,(char*)page |
inode | 94 | fs/fat/mmap.c | int fat_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 98 | fs/fat/mmap.c | if (vma->vm_offset & (inode->i_sb->s_blocksize - 1)) |
inode | 100 | fs/fat/mmap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 102 | fs/fat/mmap.c | if (!IS_RDONLY(inode)) { |
inode | 103 | fs/fat/mmap.c | inode->i_atime = CURRENT_TIME; |
inode | 104 | fs/fat/mmap.c | inode->i_dirt = 1; |
inode | 107 | fs/fat/mmap.c | vma->vm_inode = inode; |
inode | 108 | fs/fat/mmap.c | inode->i_count++; |
inode | 13 | fs/fifo.c | static int fifo_open(struct inode * inode,struct file * filp) |
inode | 27 | fs/fifo.c | if (!PIPE_READERS(*inode)++) |
inode | 28 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 29 | fs/fifo.c | if (!(filp->f_flags & O_NONBLOCK) && !PIPE_WRITERS(*inode)) { |
inode | 30 | fs/fifo.c | PIPE_RD_OPENERS(*inode)++; |
inode | 31 | fs/fifo.c | while (!PIPE_WRITERS(*inode)) { |
inode | 36 | fs/fifo.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 38 | fs/fifo.c | if (!--PIPE_RD_OPENERS(*inode)) |
inode | 39 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 41 | fs/fifo.c | while (PIPE_WR_OPENERS(*inode)) |
inode | 42 | fs/fifo.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 43 | fs/fifo.c | if (PIPE_WRITERS(*inode)) |
inode | 45 | fs/fifo.c | if (retval && !--PIPE_READERS(*inode)) |
inode | 46 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 55 | fs/fifo.c | if ((filp->f_flags & O_NONBLOCK) && !PIPE_READERS(*inode)) { |
inode | 60 | fs/fifo.c | if (!PIPE_WRITERS(*inode)++) |
inode | 61 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 62 | fs/fifo.c | if (!PIPE_READERS(*inode)) { |
inode | 63 | fs/fifo.c | PIPE_WR_OPENERS(*inode)++; |
inode | 64 | fs/fifo.c | while (!PIPE_READERS(*inode)) { |
inode | 69 | fs/fifo.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 71 | fs/fifo.c | if (!--PIPE_WR_OPENERS(*inode)) |
inode | 72 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 74 | fs/fifo.c | while (PIPE_RD_OPENERS(*inode)) |
inode | 75 | fs/fifo.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 76 | fs/fifo.c | if (retval && !--PIPE_WRITERS(*inode)) |
inode | 77 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 88 | fs/fifo.c | if (!PIPE_READERS(*inode)++) |
inode | 89 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 90 | fs/fifo.c | while (PIPE_WR_OPENERS(*inode)) |
inode | 91 | fs/fifo.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 92 | fs/fifo.c | if (!PIPE_WRITERS(*inode)++) |
inode | 93 | fs/fifo.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 94 | fs/fifo.c | while (PIPE_RD_OPENERS(*inode)) |
inode | 95 | fs/fifo.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 101 | fs/fifo.c | if (retval || PIPE_BASE(*inode)) |
inode | 104 | fs/fifo.c | if (PIPE_BASE(*inode)) { |
inode | 110 | fs/fifo.c | PIPE_LOCK(*inode) = 0; |
inode | 111 | fs/fifo.c | PIPE_START(*inode) = PIPE_LEN(*inode) = 0; |
inode | 112 | fs/fifo.c | PIPE_BASE(*inode) = (char *) page; |
inode | 154 | fs/fifo.c | void init_fifo(struct inode * inode) |
inode | 156 | fs/fifo.c | inode->i_op = &fifo_inode_operations; |
inode | 157 | fs/fifo.c | inode->i_pipe = 1; |
inode | 158 | fs/fifo.c | PIPE_LOCK(*inode) = 0; |
inode | 159 | fs/fifo.c | PIPE_BASE(*inode) = NULL; |
inode | 160 | fs/fifo.c | PIPE_START(*inode) = PIPE_LEN(*inode) = 0; |
inode | 161 | fs/fifo.c | PIPE_RD_OPENERS(*inode) = PIPE_WR_OPENERS(*inode) = 0; |
inode | 162 | fs/fifo.c | PIPE_WAIT(*inode) = NULL; |
inode | 163 | fs/fifo.c | PIPE_READERS(*inode) = PIPE_WRITERS(*inode) = 0; |
inode | 128 | fs/hpfs/hpfs_fs.c | static void hpfs_read_inode(struct inode *); |
inode | 147 | fs/hpfs/hpfs_fs.c | static int hpfs_file_read(struct inode *, struct file *, char *, int); |
inode | 148 | fs/hpfs/hpfs_fs.c | static secno hpfs_bmap(struct inode *, unsigned); |
inode | 180 | fs/hpfs/hpfs_fs.c | (int (*)(struct inode *, int)) |
inode | 188 | fs/hpfs/hpfs_fs.c | static int hpfs_dir_read(struct inode *inode, struct file *filp, |
inode | 190 | fs/hpfs/hpfs_fs.c | static int hpfs_readdir(struct inode *inode, struct file *filp, |
inode | 192 | fs/hpfs/hpfs_fs.c | static int hpfs_lookup(struct inode *, const char *, int, struct inode **); |
inode | 243 | fs/hpfs/hpfs_fs.c | static void count_dnodes(struct inode *inode, dnode_secno dno, |
inode | 247 | fs/hpfs/hpfs_fs.c | static secno bplus_lookup(struct inode *inode, struct bplus_header *b, |
inode | 249 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_dirent(struct inode *inode, dnode_secno dno, |
inode | 252 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_pos_dirent(struct inode *inode, loff_t *posp, |
inode | 254 | fs/hpfs/hpfs_fs.c | static dnode_secno dir_subdno(struct inode *inode, unsigned pos); |
inode | 634 | fs/hpfs/hpfs_fs.c | static void hpfs_read_inode(struct inode *inode) |
inode | 636 | fs/hpfs/hpfs_fs.c | struct super_block *s = inode->i_sb; |
inode | 640 | fs/hpfs/hpfs_fs.c | inode->i_op = 0; |
inode | 641 | fs/hpfs/hpfs_fs.c | inode->i_mode = 0; |
inode | 643 | fs/hpfs/hpfs_fs.c | if (inode->i_ino == 0 |
inode | 644 | fs/hpfs/hpfs_fs.c | || ino_secno(inode->i_ino) >= inode->i_sb->s_hpfs_fs_size) { |
inode | 653 | fs/hpfs/hpfs_fs.c | inode->i_uid = s->s_hpfs_uid; |
inode | 654 | fs/hpfs/hpfs_fs.c | inode->i_gid = s->s_hpfs_gid; |
inode | 655 | fs/hpfs/hpfs_fs.c | inode->i_mode = s->s_hpfs_mode; |
inode | 656 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_conv = s->s_hpfs_conv; |
inode | 658 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dno = 0; |
inode | 659 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_n_secs = 0; |
inode | 660 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_file_sec = 0; |
inode | 661 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_disk_sec = 0; |
inode | 662 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dpos = 0; |
inode | 663 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dsubdno = 0; |
inode | 669 | fs/hpfs/hpfs_fs.c | if (ino_is_dir(inode->i_ino)) |
inode | 670 | fs/hpfs/hpfs_fs.c | inode->i_mode |= S_IFDIR; |
inode | 672 | fs/hpfs/hpfs_fs.c | inode->i_mode |= S_IFREG; |
inode | 673 | fs/hpfs/hpfs_fs.c | inode->i_mode &= ~0111; |
inode | 682 | fs/hpfs/hpfs_fs.c | inode->i_atime = 0; |
inode | 683 | fs/hpfs/hpfs_fs.c | inode->i_mtime = 0; |
inode | 684 | fs/hpfs/hpfs_fs.c | inode->i_ctime = 0; |
inode | 685 | fs/hpfs/hpfs_fs.c | inode->i_size = 0; |
inode | 691 | fs/hpfs/hpfs_fs.c | if (S_ISREG(inode->i_mode)) { |
inode | 693 | fs/hpfs/hpfs_fs.c | inode->i_op = (struct inode_operations *) &hpfs_file_iops; |
inode | 694 | fs/hpfs/hpfs_fs.c | inode->i_nlink = 1; |
inode | 695 | fs/hpfs/hpfs_fs.c | inode->i_blksize = 512; |
inode | 701 | fs/hpfs/hpfs_fs.c | struct fnode *fnode = map_fnode(inode->i_dev, |
inode | 702 | fs/hpfs/hpfs_fs.c | inode->i_ino, &bh0); |
inode | 706 | fs/hpfs/hpfs_fs.c | inode->i_mode = 0; |
inode | 710 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_parent_dir = dir_ino(fnode->up); |
inode | 711 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dno = fnode->u.external[0].disk_secno; |
inode | 716 | fs/hpfs/hpfs_fs.c | count_dnodes(inode, inode->i_hpfs_dno, &n_dnodes, &n_subdirs); |
inode | 718 | fs/hpfs/hpfs_fs.c | inode->i_op = (struct inode_operations *) &hpfs_dir_iops; |
inode | 719 | fs/hpfs/hpfs_fs.c | inode->i_blksize = 512; /* 2048 here confuses ls & du & ... */ |
inode | 720 | fs/hpfs/hpfs_fs.c | inode->i_blocks = 4 * n_dnodes; |
inode | 721 | fs/hpfs/hpfs_fs.c | inode->i_size = 512 * inode->i_blocks; |
inode | 722 | fs/hpfs/hpfs_fs.c | inode->i_nlink = 2 + n_subdirs; |
inode | 785 | fs/hpfs/hpfs_fs.c | static void count_dnodes(struct inode *inode, dnode_secno dno, |
inode | 793 | fs/hpfs/hpfs_fs.c | dnode = map_dnode(inode->i_dev, dno, &qbh); |
inode | 803 | fs/hpfs/hpfs_fs.c | count_dnodes(inode, de_down_pointer(de), |
inode | 881 | fs/hpfs/hpfs_fs.c | static int hpfs_file_read(struct inode *inode, struct file *filp, |
inode | 889 | fs/hpfs/hpfs_fs.c | if (inode == 0 || !S_ISREG(inode->i_mode)) |
inode | 895 | fs/hpfs/hpfs_fs.c | if (count > inode->i_size - (off_t) filp->f_pos) |
inode | 896 | fs/hpfs/hpfs_fs.c | count = inode->i_size - filp->f_pos; |
inode | 917 | fs/hpfs/hpfs_fs.c | block = map_sector(inode->i_dev, hpfs_bmap(inode, q), &bh); |
inode | 925 | fs/hpfs/hpfs_fs.c | if (inode->i_hpfs_conv == CONV_AUTO) |
inode | 926 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_conv = choose_conv(block + r, n); |
inode | 928 | fs/hpfs/hpfs_fs.c | if (inode->i_hpfs_conv == CONV_BINARY) { |
inode | 941 | fs/hpfs/hpfs_fs.c | if (count > inode->i_size - (off_t) filp->f_pos - n + n0) |
inode | 942 | fs/hpfs/hpfs_fs.c | count = inode->i_size - filp->f_pos - n + n0; |
inode | 1012 | fs/hpfs/hpfs_fs.c | static secno hpfs_bmap(struct inode *inode, unsigned file_secno) |
inode | 1023 | fs/hpfs/hpfs_fs.c | n = file_secno - inode->i_hpfs_file_sec; |
inode | 1024 | fs/hpfs/hpfs_fs.c | if (n < inode->i_hpfs_n_secs) |
inode | 1025 | fs/hpfs/hpfs_fs.c | return inode->i_hpfs_disk_sec + n; |
inode | 1032 | fs/hpfs/hpfs_fs.c | fnode = map_fnode(inode->i_dev, inode->i_ino, &bh); |
inode | 1035 | fs/hpfs/hpfs_fs.c | disk_secno = bplus_lookup(inode, &fnode->btree, |
inode | 1049 | fs/hpfs/hpfs_fs.c | static secno bplus_lookup(struct inode *inode, struct bplus_header *b, |
inode | 1065 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_file_sec = n[i].file_secno; |
inode | 1066 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_disk_sec = n[i].disk_secno; |
inode | 1067 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_n_secs = n[i].length; |
inode | 1085 | fs/hpfs/hpfs_fs.c | anode = map_anode(inode->i_dev, ano, bhp); |
inode | 1088 | fs/hpfs/hpfs_fs.c | return bplus_lookup(inode, &anode->btree, |
inode | 1119 | fs/hpfs/hpfs_fs.c | static int hpfs_lookup(struct inode *dir, const char *name, int len, |
inode | 1120 | fs/hpfs/hpfs_fs.c | struct inode **result) |
inode | 1124 | fs/hpfs/hpfs_fs.c | struct inode *inode; |
inode | 1169 | fs/hpfs/hpfs_fs.c | if (!(inode = iget(dir->i_sb, ino))) |
inode | 1177 | fs/hpfs/hpfs_fs.c | if (!inode->i_atime) { |
inode | 1178 | fs/hpfs/hpfs_fs.c | inode->i_atime = local_to_gmt(de->read_date); |
inode | 1179 | fs/hpfs/hpfs_fs.c | inode->i_mtime = local_to_gmt(de->write_date); |
inode | 1180 | fs/hpfs/hpfs_fs.c | inode->i_ctime = local_to_gmt(de->creation_date); |
inode | 1182 | fs/hpfs/hpfs_fs.c | inode->i_mode &= ~0222; |
inode | 1184 | fs/hpfs/hpfs_fs.c | inode->i_size = de->file_size; |
inode | 1191 | fs/hpfs/hpfs_fs.c | inode->i_blocks = 1 + ((inode->i_size + 511) >> 9); |
inode | 1201 | fs/hpfs/hpfs_fs.c | *result = inode; |
inode | 1241 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_dirent(struct inode *inode, dnode_secno dno, |
inode | 1253 | fs/hpfs/hpfs_fs.c | dnode = map_dnode(inode->i_dev, dno, qbh); |
inode | 1294 | fs/hpfs/hpfs_fs.c | return map_dirent(inode, sub_dno, |
inode | 1367 | fs/hpfs/hpfs_fs.c | static int hpfs_readdir(struct inode *inode, struct file *filp, void * dirent, |
inode | 1377 | fs/hpfs/hpfs_fs.c | if (inode == 0 |
inode | 1378 | fs/hpfs/hpfs_fs.c | || inode->i_sb == 0 |
inode | 1379 | fs/hpfs/hpfs_fs.c | || !S_ISDIR(inode->i_mode)) |
inode | 1386 | fs/hpfs/hpfs_fs.c | lc = inode->i_sb->s_hpfs_lowercase; |
inode | 1392 | fs/hpfs/hpfs_fs.c | if (filldir(dirent, ".", 1, filp->f_pos, inode->i_ino) < 0) |
inode | 1398 | fs/hpfs/hpfs_fs.c | if (filldir(dirent, "..", 2, filp->f_pos, inode->i_hpfs_parent_dir) < 0) |
inode | 1406 | fs/hpfs/hpfs_fs.c | de = map_pos_dirent(inode, &filp->f_pos, &qbh); |
inode | 1433 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_pos_dirent(struct inode *inode, loff_t *posp, |
inode | 1453 | fs/hpfs/hpfs_fs.c | dno = dir_subdno(inode, q); |
inode | 1461 | fs/hpfs/hpfs_fs.c | de = map_nth_dirent(inode->i_dev, dno, r, qbh); |
inode | 1471 | fs/hpfs/hpfs_fs.c | return map_pos_dirent(inode, posp, qbh); |
inode | 1489 | fs/hpfs/hpfs_fs.c | return map_pos_dirent(inode, posp, qbh); |
inode | 1499 | fs/hpfs/hpfs_fs.c | static dnode_secno dir_subdno(struct inode *inode, unsigned pos) |
inode | 1509 | fs/hpfs/hpfs_fs.c | return inode->i_hpfs_dno; |
inode | 1515 | fs/hpfs/hpfs_fs.c | else if (pos == inode->i_hpfs_dpos) |
inode | 1516 | fs/hpfs/hpfs_fs.c | return inode->i_hpfs_dsubdno; |
inode | 1530 | fs/hpfs/hpfs_fs.c | dno = dir_subdno(inode, q); |
inode | 1537 | fs/hpfs/hpfs_fs.c | de = map_nth_dirent(inode->i_dev, dno, r, &qbh); |
inode | 1550 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dpos = pos; |
inode | 1551 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dsubdno = dno; |
inode | 1582 | fs/hpfs/hpfs_fs.c | static int hpfs_dir_read(struct inode *inode, struct file *filp, |
inode | 35 | fs/inode.c | struct inode * inode; |
inode | 39 | fs/inode.c | static struct inode * first_inode; |
inode | 55 | fs/inode.c | static inline void insert_inode_free(struct inode *inode) |
inode | 57 | fs/inode.c | struct inode * prev, * next = first_inode; |
inode | 59 | fs/inode.c | first_inode = inode; |
inode | 61 | fs/inode.c | inode->i_next = next; |
inode | 62 | fs/inode.c | inode->i_prev = prev; |
inode | 63 | fs/inode.c | prev->i_next = inode; |
inode | 64 | fs/inode.c | next->i_prev = inode; |
inode | 67 | fs/inode.c | static inline void remove_inode_free(struct inode *inode) |
inode | 69 | fs/inode.c | if (first_inode == inode) |
inode | 71 | fs/inode.c | if (inode->i_next) |
inode | 72 | fs/inode.c | inode->i_next->i_prev = inode->i_prev; |
inode | 73 | fs/inode.c | if (inode->i_prev) |
inode | 74 | fs/inode.c | inode->i_prev->i_next = inode->i_next; |
inode | 75 | fs/inode.c | inode->i_next = inode->i_prev = NULL; |
inode | 78 | fs/inode.c | void insert_inode_hash(struct inode *inode) |
inode | 81 | fs/inode.c | h = hash(inode->i_dev, inode->i_ino); |
inode | 83 | fs/inode.c | inode->i_hash_next = h->inode; |
inode | 84 | fs/inode.c | inode->i_hash_prev = NULL; |
inode | 85 | fs/inode.c | if (inode->i_hash_next) |
inode | 86 | fs/inode.c | inode->i_hash_next->i_hash_prev = inode; |
inode | 87 | fs/inode.c | h->inode = inode; |
inode | 90 | fs/inode.c | static inline void remove_inode_hash(struct inode *inode) |
inode | 93 | fs/inode.c | h = hash(inode->i_dev, inode->i_ino); |
inode | 95 | fs/inode.c | if (h->inode == inode) |
inode | 96 | fs/inode.c | h->inode = inode->i_hash_next; |
inode | 97 | fs/inode.c | if (inode->i_hash_next) |
inode | 98 | fs/inode.c | inode->i_hash_next->i_hash_prev = inode->i_hash_prev; |
inode | 99 | fs/inode.c | if (inode->i_hash_prev) |
inode | 100 | fs/inode.c | inode->i_hash_prev->i_hash_next = inode->i_hash_next; |
inode | 101 | fs/inode.c | inode->i_hash_prev = inode->i_hash_next = NULL; |
inode | 104 | fs/inode.c | static inline void put_last_free(struct inode *inode) |
inode | 106 | fs/inode.c | remove_inode_free(inode); |
inode | 107 | fs/inode.c | inode->i_prev = first_inode->i_prev; |
inode | 108 | fs/inode.c | inode->i_prev->i_next = inode; |
inode | 109 | fs/inode.c | inode->i_next = first_inode; |
inode | 110 | fs/inode.c | inode->i_next->i_prev = inode; |
inode | 115 | fs/inode.c | struct inode * inode; |
inode | 118 | fs/inode.c | if (!(inode = (struct inode*) get_free_page(GFP_KERNEL))) |
inode | 121 | fs/inode.c | i=PAGE_SIZE / sizeof(struct inode); |
inode | 126 | fs/inode.c | inode->i_next = inode->i_prev = first_inode = inode++, i--; |
inode | 129 | fs/inode.c | insert_inode_free(inode++); |
inode | 140 | fs/inode.c | static void __wait_on_inode(struct inode *); |
inode | 142 | fs/inode.c | static inline void wait_on_inode(struct inode * inode) |
inode | 144 | fs/inode.c | if (inode->i_lock) |
inode | 145 | fs/inode.c | __wait_on_inode(inode); |
inode | 148 | fs/inode.c | static inline void lock_inode(struct inode * inode) |
inode | 150 | fs/inode.c | wait_on_inode(inode); |
inode | 151 | fs/inode.c | inode->i_lock = 1; |
inode | 154 | fs/inode.c | static inline void unlock_inode(struct inode * inode) |
inode | 156 | fs/inode.c | inode->i_lock = 0; |
inode | 157 | fs/inode.c | wake_up(&inode->i_wait); |
inode | 172 | fs/inode.c | void clear_inode(struct inode * inode) |
inode | 176 | fs/inode.c | truncate_inode_pages(inode, 0); |
inode | 177 | fs/inode.c | wait_on_inode(inode); |
inode | 178 | fs/inode.c | if (IS_WRITABLE(inode)) { |
inode | 179 | fs/inode.c | if (inode->i_sb && inode->i_sb->dq_op) |
inode | 180 | fs/inode.c | inode->i_sb->dq_op->drop(inode); |
inode | 182 | fs/inode.c | remove_inode_hash(inode); |
inode | 183 | fs/inode.c | remove_inode_free(inode); |
inode | 184 | fs/inode.c | wait = ((volatile struct inode *) inode)->i_wait; |
inode | 185 | fs/inode.c | if (inode->i_count) |
inode | 187 | fs/inode.c | memset(inode,0,sizeof(*inode)); |
inode | 188 | fs/inode.c | ((volatile struct inode *) inode)->i_wait = wait; |
inode | 189 | fs/inode.c | insert_inode_free(inode); |
inode | 194 | fs/inode.c | struct inode * inode, * next; |
inode | 199 | fs/inode.c | inode = next; |
inode | 200 | fs/inode.c | next = inode->i_next; /* clear_inode() changes the queues.. */ |
inode | 201 | fs/inode.c | if (inode->i_dev != dev) |
inode | 203 | fs/inode.c | if (inode->i_count || inode->i_dirt || inode->i_lock) |
inode | 205 | fs/inode.c | clear_inode(inode); |
inode | 210 | fs/inode.c | int fs_may_umount(kdev_t dev, struct inode * mount_root) |
inode | 212 | fs/inode.c | struct inode * inode; |
inode | 215 | fs/inode.c | inode = first_inode; |
inode | 216 | fs/inode.c | for (i=0 ; i < nr_inodes ; i++, inode = inode->i_next) { |
inode | 217 | fs/inode.c | if (inode->i_dev != dev || !inode->i_count) |
inode | 219 | fs/inode.c | if (inode == mount_root && inode->i_count == |
inode | 220 | fs/inode.c | (inode->i_mount != inode ? 1 : 2)) |
inode | 243 | fs/inode.c | static void write_inode(struct inode * inode) |
inode | 245 | fs/inode.c | if (!inode->i_dirt) |
inode | 247 | fs/inode.c | wait_on_inode(inode); |
inode | 248 | fs/inode.c | if (!inode->i_dirt) |
inode | 250 | fs/inode.c | if (!inode->i_sb || !inode->i_sb->s_op || !inode->i_sb->s_op->write_inode) { |
inode | 251 | fs/inode.c | inode->i_dirt = 0; |
inode | 254 | fs/inode.c | inode->i_lock = 1; |
inode | 255 | fs/inode.c | inode->i_sb->s_op->write_inode(inode); |
inode | 256 | fs/inode.c | unlock_inode(inode); |
inode | 259 | fs/inode.c | static inline void read_inode(struct inode * inode) |
inode | 261 | fs/inode.c | lock_inode(inode); |
inode | 262 | fs/inode.c | if (inode->i_sb && inode->i_sb->s_op && inode->i_sb->s_op->read_inode) |
inode | 263 | fs/inode.c | inode->i_sb->s_op->read_inode(inode); |
inode | 264 | fs/inode.c | unlock_inode(inode); |
inode | 268 | fs/inode.c | int inode_change_ok(struct inode *inode, struct iattr *attr) |
inode | 279 | fs/inode.c | (current->fsuid != inode->i_uid || |
inode | 280 | fs/inode.c | attr->ia_uid != inode->i_uid) && !fsuser()) |
inode | 285 | fs/inode.c | (!in_group_p(attr->ia_gid) && attr->ia_gid != inode->i_gid) && |
inode | 291 | fs/inode.c | if ((current->fsuid != inode->i_uid) && !fsuser()) |
inode | 295 | fs/inode.c | inode->i_gid)) |
inode | 301 | fs/inode.c | ((current->fsuid != inode->i_uid) && !fsuser())) |
inode | 304 | fs/inode.c | ((current->fsuid != inode->i_uid) && !fsuser())) |
inode | 313 | fs/inode.c | void inode_setattr(struct inode *inode, struct iattr *attr) |
inode | 316 | fs/inode.c | inode->i_uid = attr->ia_uid; |
inode | 318 | fs/inode.c | inode->i_gid = attr->ia_gid; |
inode | 320 | fs/inode.c | inode->i_size = attr->ia_size; |
inode | 322 | fs/inode.c | inode->i_atime = attr->ia_atime; |
inode | 324 | fs/inode.c | inode->i_mtime = attr->ia_mtime; |
inode | 326 | fs/inode.c | inode->i_ctime = attr->ia_ctime; |
inode | 328 | fs/inode.c | inode->i_mode = attr->ia_mode; |
inode | 329 | fs/inode.c | if (!fsuser() && !in_group_p(inode->i_gid)) |
inode | 330 | fs/inode.c | inode->i_mode &= ~S_ISGID; |
inode | 332 | fs/inode.c | inode->i_dirt = 1; |
inode | 342 | fs/inode.c | int notify_change(struct inode * inode, struct iattr *attr) |
inode | 354 | fs/inode.c | if (inode->i_sb && inode->i_sb->s_op && |
inode | 355 | fs/inode.c | inode->i_sb->s_op->notify_change) |
inode | 356 | fs/inode.c | return inode->i_sb->s_op->notify_change(inode, attr); |
inode | 358 | fs/inode.c | if ((retval = inode_change_ok(inode, attr)) != 0) |
inode | 361 | fs/inode.c | inode_setattr(inode, attr); |
inode | 375 | fs/inode.c | int bmap(struct inode * inode, int block) |
inode | 377 | fs/inode.c | if (inode->i_op && inode->i_op->bmap) |
inode | 378 | fs/inode.c | return inode->i_op->bmap(inode,block); |
inode | 384 | fs/inode.c | struct inode * inode, * next; |
inode | 389 | fs/inode.c | inode = next; |
inode | 390 | fs/inode.c | next = inode->i_next; /* clear_inode() changes the queues.. */ |
inode | 391 | fs/inode.c | if (inode->i_dev != dev) |
inode | 393 | fs/inode.c | if (inode->i_count || inode->i_dirt || inode->i_lock) { |
inode | 398 | fs/inode.c | clear_inode(inode); |
inode | 405 | fs/inode.c | struct inode * inode; |
inode | 407 | fs/inode.c | inode = first_inode; |
inode | 408 | fs/inode.c | for(i = 0; i < nr_inodes*2; i++, inode = inode->i_next) { |
inode | 409 | fs/inode.c | if (dev && inode->i_dev != dev) |
inode | 411 | fs/inode.c | wait_on_inode(inode); |
inode | 412 | fs/inode.c | if (inode->i_dirt) |
inode | 413 | fs/inode.c | write_inode(inode); |
inode | 417 | fs/inode.c | void iput(struct inode * inode) |
inode | 419 | fs/inode.c | if (!inode) |
inode | 421 | fs/inode.c | wait_on_inode(inode); |
inode | 422 | fs/inode.c | if (!inode->i_count) { |
inode | 425 | fs/inode.c | kdevname(inode->i_rdev), inode->i_ino, inode->i_mode); |
inode | 428 | fs/inode.c | if (inode->i_pipe) |
inode | 429 | fs/inode.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 431 | fs/inode.c | if (inode->i_count>1) { |
inode | 432 | fs/inode.c | inode->i_count--; |
inode | 437 | fs/inode.c | if (inode->i_pipe) { |
inode | 438 | fs/inode.c | unsigned long page = (unsigned long) PIPE_BASE(*inode); |
inode | 439 | fs/inode.c | PIPE_BASE(*inode) = NULL; |
inode | 443 | fs/inode.c | if (inode->i_sb && inode->i_sb->s_op && inode->i_sb->s_op->put_inode) { |
inode | 444 | fs/inode.c | inode->i_sb->s_op->put_inode(inode); |
inode | 445 | fs/inode.c | if (!inode->i_nlink) |
inode | 449 | fs/inode.c | if (inode->i_dirt) { |
inode | 450 | fs/inode.c | write_inode(inode); /* we can sleep - so do again */ |
inode | 451 | fs/inode.c | wait_on_inode(inode); |
inode | 455 | fs/inode.c | if (IS_WRITABLE(inode)) { |
inode | 456 | fs/inode.c | if (inode->i_sb && inode->i_sb->dq_op) { |
inode | 460 | fs/inode.c | inode->i_lock = 1; |
inode | 461 | fs/inode.c | inode->i_sb->dq_op->drop(inode); |
inode | 462 | fs/inode.c | unlock_inode(inode); |
inode | 467 | fs/inode.c | inode->i_count--; |
inode | 469 | fs/inode.c | if (inode->i_mmap) { |
inode | 471 | fs/inode.c | inode->i_ino, kdevname(inode->i_dev)); |
inode | 472 | fs/inode.c | inode->i_mmap = NULL; |
inode | 479 | fs/inode.c | static inline unsigned long value(struct inode * inode) |
inode | 481 | fs/inode.c | if (inode->i_lock) |
inode | 483 | fs/inode.c | if (inode->i_dirt) |
inode | 485 | fs/inode.c | return inode->i_nrpages; |
inode | 488 | fs/inode.c | struct inode * get_empty_inode(void) |
inode | 491 | fs/inode.c | struct inode * inode, * best; |
inode | 498 | fs/inode.c | inode = first_inode; |
inode | 500 | fs/inode.c | for (i = nr_inodes/2; i > 0; i--,inode = inode->i_next) { |
inode | 501 | fs/inode.c | if (!inode->i_count) { |
inode | 502 | fs/inode.c | unsigned long i = value(inode); |
inode | 504 | fs/inode.c | best = inode; |
inode | 515 | fs/inode.c | inode = best; |
inode | 516 | fs/inode.c | if (!inode) { |
inode | 521 | fs/inode.c | if (inode->i_lock) { |
inode | 522 | fs/inode.c | wait_on_inode(inode); |
inode | 525 | fs/inode.c | if (inode->i_dirt) { |
inode | 526 | fs/inode.c | write_inode(inode); |
inode | 529 | fs/inode.c | if (inode->i_count) |
inode | 531 | fs/inode.c | clear_inode(inode); |
inode | 532 | fs/inode.c | inode->i_count = 1; |
inode | 533 | fs/inode.c | inode->i_nlink = 1; |
inode | 534 | fs/inode.c | inode->i_version = ++event; |
inode | 535 | fs/inode.c | inode->i_sem.count = 1; |
inode | 536 | fs/inode.c | inode->i_ino = ++ino; |
inode | 537 | fs/inode.c | inode->i_dev = 0; |
inode | 543 | fs/inode.c | return inode; |
inode | 546 | fs/inode.c | struct inode * get_pipe_inode(void) |
inode | 548 | fs/inode.c | struct inode * inode; |
inode | 551 | fs/inode.c | if (!(inode = get_empty_inode())) |
inode | 553 | fs/inode.c | if (!(PIPE_BASE(*inode) = (char*) __get_free_page(GFP_USER))) { |
inode | 554 | fs/inode.c | iput(inode); |
inode | 557 | fs/inode.c | inode->i_op = &pipe_inode_operations; |
inode | 558 | fs/inode.c | inode->i_count = 2; /* sum of readers/writers */ |
inode | 559 | fs/inode.c | PIPE_WAIT(*inode) = NULL; |
inode | 560 | fs/inode.c | PIPE_START(*inode) = PIPE_LEN(*inode) = 0; |
inode | 561 | fs/inode.c | PIPE_RD_OPENERS(*inode) = PIPE_WR_OPENERS(*inode) = 0; |
inode | 562 | fs/inode.c | PIPE_READERS(*inode) = PIPE_WRITERS(*inode) = 1; |
inode | 563 | fs/inode.c | PIPE_LOCK(*inode) = 0; |
inode | 564 | fs/inode.c | inode->i_pipe = 1; |
inode | 565 | fs/inode.c | inode->i_mode |= S_IFIFO | S_IRUSR | S_IWUSR; |
inode | 566 | fs/inode.c | inode->i_uid = current->fsuid; |
inode | 567 | fs/inode.c | inode->i_gid = current->fsgid; |
inode | 568 | fs/inode.c | inode->i_atime = inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 569 | fs/inode.c | inode->i_blksize = PAGE_SIZE; |
inode | 570 | fs/inode.c | return inode; |
inode | 573 | fs/inode.c | struct inode *__iget(struct super_block * sb, int nr, int crossmntp) |
inode | 577 | fs/inode.c | struct inode * inode; |
inode | 578 | fs/inode.c | struct inode * empty = NULL; |
inode | 584 | fs/inode.c | for (inode = h->inode; inode ; inode = inode->i_hash_next) |
inode | 585 | fs/inode.c | if (inode->i_dev == sb->s_dev && inode->i_ino == nr) |
inode | 603 | fs/inode.c | inode = empty; |
inode | 604 | fs/inode.c | inode->i_sb = sb; |
inode | 605 | fs/inode.c | inode->i_dev = sb->s_dev; |
inode | 606 | fs/inode.c | inode->i_ino = nr; |
inode | 607 | fs/inode.c | inode->i_flags = sb->s_flags; |
inode | 608 | fs/inode.c | put_last_free(inode); |
inode | 609 | fs/inode.c | insert_inode_hash(inode); |
inode | 610 | fs/inode.c | read_inode(inode); |
inode | 614 | fs/inode.c | if (!inode->i_count) |
inode | 616 | fs/inode.c | inode->i_count++; |
inode | 617 | fs/inode.c | wait_on_inode(inode); |
inode | 618 | fs/inode.c | if (inode->i_dev != sb->s_dev || inode->i_ino != nr) { |
inode | 620 | fs/inode.c | iput(inode); |
inode | 623 | fs/inode.c | if (crossmntp && inode->i_mount) { |
inode | 624 | fs/inode.c | struct inode * tmp = inode->i_mount; |
inode | 626 | fs/inode.c | iput(inode); |
inode | 627 | fs/inode.c | inode = tmp; |
inode | 628 | fs/inode.c | wait_on_inode(inode); |
inode | 636 | fs/inode.c | return inode; |
inode | 645 | fs/inode.c | static void __wait_on_inode(struct inode * inode) |
inode | 649 | fs/inode.c | add_wait_queue(&inode->i_wait, &wait); |
inode | 652 | fs/inode.c | if (inode->i_lock) { |
inode | 656 | fs/inode.c | remove_wait_queue(&inode->i_wait, &wait); |
inode | 24 | fs/isofs/dir.c | static int isofs_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 63 | fs/isofs/dir.c | static int parent_inode_number(struct inode * inode, struct iso_directory_record * de) |
inode | 65 | fs/isofs/dir.c | int inode_number = inode->i_ino; |
inode | 67 | fs/isofs/dir.c | if ((inode->i_sb->u.isofs_sb.s_firstdatazone) != inode->i_ino) |
inode | 68 | fs/isofs/dir.c | inode_number = inode->u.isofs_i.i_backlink; |
inode | 74 | fs/isofs/dir.c | return isofs_lookup_grandparent(inode, find_rock_ridge_relocation(de, inode)); |
inode | 108 | fs/isofs/dir.c | static int do_isofs_readdir(struct inode *inode, struct file *filp, |
inode | 112 | fs/isofs/dir.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(inode); |
inode | 113 | fs/isofs/dir.c | unsigned char bufbits = ISOFS_BUFFER_BITS(inode); |
inode | 123 | fs/isofs/dir.c | block = isofs_bmap(inode, filp->f_pos >> bufbits); |
inode | 128 | fs/isofs/dir.c | if (!(bh = breada(inode->i_dev, block, bufsize, filp->f_pos, inode->i_size))) |
inode | 131 | fs/isofs/dir.c | while (filp->f_pos < inode->i_size) { |
inode | 141 | fs/isofs/dir.c | block = isofs_bmap(inode, (filp->f_pos) >> bufbits); |
inode | 144 | fs/isofs/dir.c | bh = breada(inode->i_dev, block, bufsize, filp->f_pos, inode->i_size); |
inode | 164 | fs/isofs/dir.c | block = isofs_bmap(inode, (filp->f_pos) >> bufbits); |
inode | 167 | fs/isofs/dir.c | bh = breada(inode->i_dev, block, bufsize, filp->f_pos, inode->i_size); |
inode | 181 | fs/isofs/dir.c | block = isofs_bmap(inode, (filp->f_pos + de_len) >> bufbits); |
inode | 184 | fs/isofs/dir.c | bh = breada(inode->i_dev, block, bufsize, filp->f_pos+de_len, inode->i_size); |
inode | 194 | fs/isofs/dir.c | if (filldir(dirent, ".", 1, filp->f_pos, inode->i_ino) < 0) |
inode | 202 | fs/isofs/dir.c | inode_number = parent_inode_number(inode, de); |
inode | 214 | fs/isofs/dir.c | if (inode->i_sb->u.isofs_sb.s_unhide == 'n') { |
inode | 216 | fs/isofs/dir.c | high_sierra = inode->i_sb->u.isofs_sb.s_high_sierra; |
inode | 226 | fs/isofs/dir.c | rrflag = get_rock_ridge_filename(de, &name, &len, inode); |
inode | 231 | fs/isofs/dir.c | dcache_add(inode, name, len, inode_number); |
inode | 240 | fs/isofs/dir.c | if (inode->i_sb->u.isofs_sb.s_mapping == 'n') { |
inode | 244 | fs/isofs/dir.c | dcache_add(inode, tmpname, len, inode_number); |
inode | 252 | fs/isofs/dir.c | dcache_add(inode, name, len, inode_number); |
inode | 265 | fs/isofs/dir.c | static int isofs_readdir(struct inode *inode, struct file *filp, |
inode | 272 | fs/isofs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 280 | fs/isofs/dir.c | result = do_isofs_readdir(inode, filp, dirent, filldir, tmpname, tmpde); |
inode | 169 | fs/isofs/inode.c | struct inode inode_fake; |
inode | 449 | fs/isofs/inode.c | int isofs_bmap(struct inode * inode,int block) |
inode | 456 | fs/isofs/inode.c | return (inode->u.isofs_i.i_first_extent >> ISOFS_BUFFER_BITS(inode)) + block; |
inode | 459 | fs/isofs/inode.c | void isofs_read_inode(struct inode * inode) |
inode | 461 | fs/isofs/inode.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(inode); |
inode | 471 | fs/isofs/inode.c | block = inode->i_ino >> ISOFS_BUFFER_BITS(inode); |
inode | 472 | fs/isofs/inode.c | if (!(bh=bread(inode->i_dev,block, bufsize))) { |
inode | 478 | fs/isofs/inode.c | + (inode->i_ino & (bufsize - 1))); |
inode | 480 | fs/isofs/inode.c | high_sierra = inode->i_sb->u.isofs_sb.s_high_sierra; |
inode | 482 | fs/isofs/inode.c | if ((inode->i_ino & (bufsize - 1)) + *pnt > bufsize){ |
inode | 485 | fs/isofs/inode.c | offset = (inode->i_ino & (bufsize - 1)); |
inode | 489 | fs/isofs/inode.c | printk(KERN_INFO "NoMem ISO inode %lu\n",inode->i_ino); |
inode | 495 | fs/isofs/inode.c | if (!(bh = bread(inode->i_dev,++block, bufsize))) { |
inode | 507 | fs/isofs/inode.c | inode->i_mode = S_IRUGO | S_IXUGO | S_IFDIR; |
inode | 508 | fs/isofs/inode.c | inode->i_nlink = 1; /* Set to 1. We know there are 2, but |
inode | 514 | fs/isofs/inode.c | inode->i_mode = inode->i_sb->u.isofs_sb.s_mode; /* Everybody gets to read the file. */ |
inode | 515 | fs/isofs/inode.c | inode->i_nlink = 1; |
inode | 516 | fs/isofs/inode.c | inode->i_mode |= S_IFREG; |
inode | 522 | fs/isofs/inode.c | inode->i_mode |= S_IXUGO; /* execute permission */ |
inode | 524 | fs/isofs/inode.c | inode->i_uid = inode->i_sb->u.isofs_sb.s_uid; |
inode | 525 | fs/isofs/inode.c | inode->i_gid = inode->i_sb->u.isofs_sb.s_gid; |
inode | 526 | fs/isofs/inode.c | inode->i_size = isonum_733 (raw_inode->size); |
inode | 530 | fs/isofs/inode.c | if((inode->i_size < 0 || inode->i_size > 800000000) && |
inode | 531 | fs/isofs/inode.c | inode->i_sb->u.isofs_sb.s_cruft == 'n') { |
inode | 533 | fs/isofs/inode.c | inode->i_sb->u.isofs_sb.s_cruft = 'y'; |
inode | 540 | fs/isofs/inode.c | if(inode->i_sb->u.isofs_sb.s_cruft == 'y' && |
inode | 541 | fs/isofs/inode.c | inode->i_size & 0xff000000){ |
inode | 543 | fs/isofs/inode.c | inode->i_size &= 0x00ffffff; |
inode | 548 | fs/isofs/inode.c | inode->i_size = 0; |
inode | 554 | fs/isofs/inode.c | printk("File unit size != 0 for ISO file (%ld).\n",inode->i_ino); |
inode | 562 | fs/isofs/inode.c | inode->i_ino, raw_inode->flags[-high_sierra]); |
inode | 567 | fs/isofs/inode.c | printk("Get inode %d: %d %d: %d\n",inode->i_ino, block, |
inode | 568 | fs/isofs/inode.c | ((int)pnt) & 0x3ff, inode->i_size); |
inode | 571 | fs/isofs/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = |
inode | 574 | fs/isofs/inode.c | inode->u.isofs_i.i_first_extent = (isonum_733 (raw_inode->extent) + |
inode | 576 | fs/isofs/inode.c | << inode -> i_sb -> u.isofs_sb.s_log_zone_size; |
inode | 578 | fs/isofs/inode.c | inode->u.isofs_i.i_backlink = 0xffffffff; /* Will be used for previous directory */ |
inode | 579 | fs/isofs/inode.c | switch (inode->i_sb->u.isofs_sb.s_conversion){ |
inode | 581 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_UNKNOWN; /* File type */ |
inode | 584 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_BINARY; /* File type */ |
inode | 587 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_TEXT; /* File type */ |
inode | 590 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_TEXT_M; /* File type */ |
inode | 598 | fs/isofs/inode.c | parse_rock_ridge_inode(raw_inode, inode); |
inode | 601 | fs/isofs/inode.c | printk("Inode: %x extent: %x\n",inode->i_ino, inode->u.isofs_i.i_first_extent); |
inode | 605 | fs/isofs/inode.c | inode->i_op = NULL; |
inode | 616 | fs/isofs/inode.c | if (inode->i_sb->u.isofs_sb.s_cruft == 'n' && |
inode | 619 | fs/isofs/inode.c | inode->i_sb->u.isofs_sb.s_cruft = 'y'; |
inode | 623 | fs/isofs/inode.c | if (inode->i_sb->u.isofs_sb.s_cruft != 'y' && |
inode | 629 | fs/isofs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 630 | fs/isofs/inode.c | inode->i_op = &isofs_file_inode_operations; |
inode | 631 | fs/isofs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 632 | fs/isofs/inode.c | inode->i_op = &isofs_dir_inode_operations; |
inode | 633 | fs/isofs/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 634 | fs/isofs/inode.c | inode->i_op = &isofs_symlink_inode_operations; |
inode | 635 | fs/isofs/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 636 | fs/isofs/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 637 | fs/isofs/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 638 | fs/isofs/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 639 | fs/isofs/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 640 | fs/isofs/inode.c | init_fifo(inode); |
inode | 649 | fs/isofs/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = 0; |
inode | 650 | fs/isofs/inode.c | inode->u.isofs_i.i_first_extent = 0; |
inode | 651 | fs/isofs/inode.c | inode->u.isofs_i.i_backlink = 0xffffffff; |
inode | 652 | fs/isofs/inode.c | inode->i_size = 0; |
inode | 653 | fs/isofs/inode.c | inode->i_nlink = 1; |
inode | 654 | fs/isofs/inode.c | inode->i_uid = inode->i_gid = 0; |
inode | 655 | fs/isofs/inode.c | inode->i_mode = S_IFREG; /*Regular file, no one gets to read*/ |
inode | 656 | fs/isofs/inode.c | inode->i_op = NULL; |
inode | 679 | fs/isofs/inode.c | int isofs_lookup_grandparent(struct inode * parent, int extent) |
inode | 61 | fs/isofs/namei.c | static struct buffer_head * isofs_find_entry(struct inode * dir, |
inode | 220 | fs/isofs/namei.c | int isofs_lookup(struct inode * dir,const char * name, int len, |
inode | 221 | fs/isofs/namei.c | struct inode ** result) |
inode | 98 | fs/isofs/rock.c | struct inode * inode) { |
inode | 113 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) return retval; |
inode | 163 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat, inode); |
inode | 171 | fs/isofs/rock.c | char ** name, int * namlen, struct inode * inode) |
inode | 179 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) return 0; |
inode | 231 | fs/isofs/rock.c | printk("RR: RE (%x)\n", inode->i_ino); |
inode | 241 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat,inode); |
inode | 255 | fs/isofs/rock.c | struct inode * inode){ |
inode | 261 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) return 0; |
inode | 267 | fs/isofs/rock.c | struct inode * reloc; |
inode | 297 | fs/isofs/rock.c | inode->i_mode = isonum_733(rr->u.PX.mode); |
inode | 298 | fs/isofs/rock.c | inode->i_nlink = isonum_733(rr->u.PX.n_links); |
inode | 299 | fs/isofs/rock.c | inode->i_uid = isonum_733(rr->u.PX.uid); |
inode | 300 | fs/isofs/rock.c | inode->i_gid = isonum_733(rr->u.PX.gid); |
inode | 314 | fs/isofs/rock.c | inode->i_rdev = MKDEV(low >> 8, low & 0xff); |
inode | 316 | fs/isofs/rock.c | inode->i_rdev = MKDEV(high, low); |
inode | 325 | fs/isofs/rock.c | inode->i_ctime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 327 | fs/isofs/rock.c | inode->i_mtime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 329 | fs/isofs/rock.c | inode->i_atime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 331 | fs/isofs/rock.c | inode->i_ctime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 338 | fs/isofs/rock.c | inode->i_size = symlink_len; |
inode | 343 | fs/isofs/rock.c | inode->i_size += slp->len; |
inode | 346 | fs/isofs/rock.c | inode->i_size += 1; |
inode | 349 | fs/isofs/rock.c | inode->i_size += 2; |
inode | 353 | fs/isofs/rock.c | inode->i_size += 1; |
inode | 362 | fs/isofs/rock.c | if(!rootflag) inode->i_size += 1; |
inode | 365 | fs/isofs/rock.c | symlink_len = inode->i_size; |
inode | 372 | fs/isofs/rock.c | printk("RR CL (%x)\n",inode->i_ino); |
inode | 374 | fs/isofs/rock.c | inode->u.isofs_i.i_first_extent = isonum_733(rr->u.CL.location) << |
inode | 375 | fs/isofs/rock.c | inode -> i_sb -> u.isofs_sb.s_log_zone_size; |
inode | 376 | fs/isofs/rock.c | reloc = iget(inode->i_sb, inode->u.isofs_i.i_first_extent); |
inode | 377 | fs/isofs/rock.c | inode->i_mode = reloc->i_mode; |
inode | 378 | fs/isofs/rock.c | inode->i_nlink = reloc->i_nlink; |
inode | 379 | fs/isofs/rock.c | inode->i_uid = reloc->i_uid; |
inode | 380 | fs/isofs/rock.c | inode->i_gid = reloc->i_gid; |
inode | 381 | fs/isofs/rock.c | inode->i_rdev = reloc->i_rdev; |
inode | 382 | fs/isofs/rock.c | inode->i_size = reloc->i_size; |
inode | 383 | fs/isofs/rock.c | inode->i_atime = reloc->i_atime; |
inode | 384 | fs/isofs/rock.c | inode->i_ctime = reloc->i_ctime; |
inode | 385 | fs/isofs/rock.c | inode->i_mtime = reloc->i_mtime; |
inode | 393 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat,inode); |
inode | 404 | fs/isofs/rock.c | char * get_rock_ridge_symlink(struct inode * inode) |
inode | 406 | fs/isofs/rock.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(inode); |
inode | 407 | fs/isofs/rock.c | unsigned char bufbits = ISOFS_BUFFER_BITS(inode); |
inode | 421 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) |
inode | 426 | fs/isofs/rock.c | block = inode->i_ino >> bufbits; |
inode | 427 | fs/isofs/rock.c | if (!(bh=bread(inode->i_dev,block, bufsize))) { |
inode | 432 | fs/isofs/rock.c | pnt = ((unsigned char *) bh->b_data) + (inode->i_ino & (bufsize - 1)); |
inode | 436 | fs/isofs/rock.c | if ((inode->i_ino & (bufsize - 1)) + *pnt > bufsize){ |
inode | 439 | fs/isofs/rock.c | offset = (inode->i_ino & (bufsize - 1)); |
inode | 445 | fs/isofs/rock.c | if (!(bh = bread(inode->i_dev,++block, bufsize))) { |
inode | 483 | fs/isofs/rock.c | rpnt = (char *) kmalloc (inode->i_size +1, GFP_KERNEL); |
inode | 520 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat,inode); |
inode | 21 | fs/isofs/symlink.c | static int isofs_readlink(struct inode *, char *, int); |
inode | 22 | fs/isofs/symlink.c | static int isofs_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 47 | fs/isofs/symlink.c | static int isofs_follow_link(struct inode * dir, struct inode * inode, |
inode | 48 | fs/isofs/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 57 | fs/isofs/symlink.c | if (!inode) { |
inode | 62 | fs/isofs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 64 | fs/isofs/symlink.c | *res_inode = inode; |
inode | 68 | fs/isofs/symlink.c | !(pnt = get_rock_ridge_symlink(inode))) { |
inode | 70 | fs/isofs/symlink.c | iput(inode); |
inode | 74 | fs/isofs/symlink.c | iput(inode); |
inode | 82 | fs/isofs/symlink.c | static int isofs_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 88 | fs/isofs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 89 | fs/isofs/symlink.c | iput(inode); |
inode | 95 | fs/isofs/symlink.c | pnt = get_rock_ridge_symlink(inode); |
inode | 97 | fs/isofs/symlink.c | iput(inode); |
inode | 233 | fs/locks.c | struct inode *inode; |
inode | 246 | fs/locks.c | if (!(inode = filp->f_inode)) |
inode | 252 | fs/locks.c | if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID && inode->i_mmap) { |
inode | 253 | fs/locks.c | struct vm_area_struct *vma = inode->i_mmap; |
inode | 258 | fs/locks.c | } while (vma != inode->i_mmap); |
inode | 322 | fs/locks.c | int locks_verify_locked(struct inode *inode) |
inode | 327 | fs/locks.c | if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) |
inode | 328 | fs/locks.c | return (locks_mandatory_locked(inode)); |
inode | 332 | fs/locks.c | int locks_mandatory_locked(struct inode *inode) |
inode | 338 | fs/locks.c | for (fl = inode->i_flock; fl != NULL; fl = fl->fl_next) { |
inode | 345 | fs/locks.c | int locks_verify_area(int read_write, struct inode *inode, struct file *filp, |
inode | 351 | fs/locks.c | if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) |
inode | 352 | fs/locks.c | return (locks_mandatory_area(read_write, inode, filp, offset, |
inode | 357 | fs/locks.c | int locks_mandatory_area(int read_write, struct inode *inode, |
inode | 368 | fs/locks.c | for (fl = inode->i_flock; fl != NULL; fl = fl->fl_next) { |
inode | 394 | fs/locks.c | if ((inode->i_mode & (S_ISGID | S_IXGRP)) != S_ISGID) |
inode | 110 | fs/minix/bitmap.c | static struct buffer_head *V1_minix_clear_inode(struct inode *inode) |
inode | 116 | fs/minix/bitmap.c | ino = inode->i_ino; |
inode | 117 | fs/minix/bitmap.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 119 | fs/minix/bitmap.c | kdevname(inode->i_dev), ino); |
inode | 122 | fs/minix/bitmap.c | block = (2 + inode->i_sb->u.minix_sb.s_imap_blocks + |
inode | 123 | fs/minix/bitmap.c | inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 125 | fs/minix/bitmap.c | bh = bread(inode->i_dev, block, BLOCK_SIZE); |
inode | 138 | fs/minix/bitmap.c | static struct buffer_head *V2_minix_clear_inode(struct inode *inode) |
inode | 144 | fs/minix/bitmap.c | ino = inode->i_ino; |
inode | 145 | fs/minix/bitmap.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 147 | fs/minix/bitmap.c | kdevname(inode->i_dev), ino); |
inode | 150 | fs/minix/bitmap.c | block = (2 + inode->i_sb->u.minix_sb.s_imap_blocks + |
inode | 151 | fs/minix/bitmap.c | inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 153 | fs/minix/bitmap.c | bh = bread(inode->i_dev, block, BLOCK_SIZE); |
inode | 168 | fs/minix/bitmap.c | static void minix_clear_inode(struct inode *inode) |
inode | 171 | fs/minix/bitmap.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 172 | fs/minix/bitmap.c | bh = V1_minix_clear_inode(inode); |
inode | 174 | fs/minix/bitmap.c | bh = V2_minix_clear_inode(inode); |
inode | 178 | fs/minix/bitmap.c | void minix_free_inode(struct inode * inode) |
inode | 183 | fs/minix/bitmap.c | if (!inode) |
inode | 185 | fs/minix/bitmap.c | if (!inode->i_dev) { |
inode | 189 | fs/minix/bitmap.c | if (inode->i_count != 1) { |
inode | 190 | fs/minix/bitmap.c | printk("free_inode: inode has count=%d\n",inode->i_count); |
inode | 193 | fs/minix/bitmap.c | if (inode->i_nlink) { |
inode | 194 | fs/minix/bitmap.c | printk("free_inode: inode has nlink=%d\n",inode->i_nlink); |
inode | 197 | fs/minix/bitmap.c | if (!inode->i_sb) { |
inode | 201 | fs/minix/bitmap.c | if (inode->i_ino < 1 || inode->i_ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 205 | fs/minix/bitmap.c | ino = inode->i_ino; |
inode | 206 | fs/minix/bitmap.c | if (!(bh=inode->i_sb->u.minix_sb.s_imap[ino >> 13])) { |
inode | 210 | fs/minix/bitmap.c | minix_clear_inode(inode); |
inode | 211 | fs/minix/bitmap.c | clear_inode(inode); |
inode | 217 | fs/minix/bitmap.c | struct inode * minix_new_inode(const struct inode * dir) |
inode | 220 | fs/minix/bitmap.c | struct inode * inode; |
inode | 224 | fs/minix/bitmap.c | if (!dir || !(inode = get_empty_inode())) |
inode | 227 | fs/minix/bitmap.c | inode->i_sb = sb; |
inode | 228 | fs/minix/bitmap.c | inode->i_flags = inode->i_sb->s_flags; |
inode | 231 | fs/minix/bitmap.c | if ((bh = inode->i_sb->u.minix_sb.s_imap[i]) != NULL) |
inode | 235 | fs/minix/bitmap.c | iput(inode); |
inode | 240 | fs/minix/bitmap.c | iput(inode); |
inode | 245 | fs/minix/bitmap.c | if (!j || j >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 246 | fs/minix/bitmap.c | iput(inode); |
inode | 249 | fs/minix/bitmap.c | inode->i_count = 1; |
inode | 250 | fs/minix/bitmap.c | inode->i_nlink = 1; |
inode | 251 | fs/minix/bitmap.c | inode->i_dev = sb->s_dev; |
inode | 252 | fs/minix/bitmap.c | inode->i_uid = current->fsuid; |
inode | 253 | fs/minix/bitmap.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 254 | fs/minix/bitmap.c | inode->i_dirt = 1; |
inode | 255 | fs/minix/bitmap.c | inode->i_ino = j; |
inode | 256 | fs/minix/bitmap.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 257 | fs/minix/bitmap.c | inode->i_op = NULL; |
inode | 258 | fs/minix/bitmap.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 259 | fs/minix/bitmap.c | insert_inode_hash(inode); |
inode | 260 | fs/minix/bitmap.c | return inode; |
inode | 17 | fs/minix/dir.c | static int minix_dir_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 22 | fs/minix/dir.c | static int minix_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 60 | fs/minix/dir.c | static int minix_readdir(struct inode * inode, struct file * filp, |
inode | 68 | fs/minix/dir.c | if (!inode || !inode->i_sb || !S_ISDIR(inode->i_mode)) |
inode | 70 | fs/minix/dir.c | info = &inode->i_sb->u.minix_sb; |
inode | 73 | fs/minix/dir.c | while (filp->f_pos < inode->i_size) { |
inode | 75 | fs/minix/dir.c | bh = minix_bread(inode,(filp->f_pos)>>BLOCK_SIZE_BITS,0); |
inode | 82 | fs/minix/dir.c | if (de->inode) { |
inode | 84 | fs/minix/dir.c | if (filldir(dirent, de->name, size, filp->f_pos, de->inode) < 0) { |
inode | 91 | fs/minix/dir.c | } while (offset < 1024 && filp->f_pos < inode->i_size); |
inode | 30 | fs/minix/file.c | static int minix_file_write(struct inode *, struct file *, const char *, int); |
inode | 69 | fs/minix/file.c | static int minix_file_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 76 | fs/minix/file.c | if (!inode) { |
inode | 80 | fs/minix/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 81 | fs/minix/file.c | printk("minix_file_write: mode = %07o\n",inode->i_mode); |
inode | 85 | fs/minix/file.c | pos = inode->i_size; |
inode | 90 | fs/minix/file.c | bh = minix_getblk(inode,pos/BLOCK_SIZE,1); |
inode | 111 | fs/minix/file.c | update_vm_cache(inode, pos, p, c); |
inode | 119 | fs/minix/file.c | if (pos > inode->i_size) |
inode | 120 | fs/minix/file.c | inode->i_size = pos; |
inode | 121 | fs/minix/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 123 | fs/minix/file.c | inode->i_dirt = 1; |
inode | 31 | fs/minix/fsync.c | static int V1_sync_block (struct inode * inode, unsigned short * block, int wait) |
inode | 39 | fs/minix/fsync.c | bh = get_hash_table(inode->i_dev, *block, blocksize); |
inode | 60 | fs/minix/fsync.c | static int V1_sync_iblock (struct inode * inode, unsigned short * iblock, |
inode | 70 | fs/minix/fsync.c | rc = V1_sync_block (inode, iblock, wait); |
inode | 73 | fs/minix/fsync.c | *bh = bread(inode->i_dev, tmp, blocksize); |
inode | 84 | fs/minix/fsync.c | static int V1_sync_direct(struct inode *inode, int wait) |
inode | 90 | fs/minix/fsync.c | rc = V1_sync_block (inode, |
inode | 91 | fs/minix/fsync.c | (unsigned short *) inode->u.minix_i.u.i1_data + i, wait); |
inode | 100 | fs/minix/fsync.c | static int V1_sync_indirect(struct inode *inode, unsigned short *iblock, int wait) |
inode | 106 | fs/minix/fsync.c | rc = V1_sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 111 | fs/minix/fsync.c | rc = V1_sync_block (inode, |
inode | 123 | fs/minix/fsync.c | static int V1_sync_dindirect(struct inode *inode, unsigned short *diblock, |
inode | 130 | fs/minix/fsync.c | rc = V1_sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 135 | fs/minix/fsync.c | rc = V1_sync_indirect (inode, |
inode | 147 | fs/minix/fsync.c | int V1_minix_sync_file(struct inode * inode, struct file * file) |
inode | 151 | fs/minix/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 152 | fs/minix/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 157 | fs/minix/fsync.c | err |= V1_sync_direct(inode, wait); |
inode | 158 | fs/minix/fsync.c | err |= V1_sync_indirect(inode, inode->u.minix_i.u.i1_data + 7, wait); |
inode | 159 | fs/minix/fsync.c | err |= V1_sync_dindirect(inode, inode->u.minix_i.u.i1_data + 8, wait); |
inode | 161 | fs/minix/fsync.c | err |= minix_sync_inode (inode); |
inode | 168 | fs/minix/fsync.c | static int V2_sync_block (struct inode * inode, unsigned long * block, int wait) |
inode | 176 | fs/minix/fsync.c | bh = get_hash_table(inode->i_dev, *block, blocksize); |
inode | 197 | fs/minix/fsync.c | static int V2_sync_iblock (struct inode * inode, unsigned long * iblock, |
inode | 207 | fs/minix/fsync.c | rc = V2_sync_block (inode, iblock, wait); |
inode | 210 | fs/minix/fsync.c | *bh = bread(inode->i_dev, tmp, blocksize); |
inode | 221 | fs/minix/fsync.c | static int V2_sync_direct(struct inode *inode, int wait) |
inode | 227 | fs/minix/fsync.c | rc = V2_sync_block (inode, |
inode | 228 | fs/minix/fsync.c | (unsigned long *)inode->u.minix_i.u.i2_data + i, wait); |
inode | 237 | fs/minix/fsync.c | static int V2_sync_indirect(struct inode *inode, unsigned long *iblock, int wait) |
inode | 243 | fs/minix/fsync.c | rc = V2_sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 248 | fs/minix/fsync.c | rc = V2_sync_block (inode, |
inode | 260 | fs/minix/fsync.c | static int V2_sync_dindirect(struct inode *inode, unsigned long *diblock, |
inode | 267 | fs/minix/fsync.c | rc = V2_sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 272 | fs/minix/fsync.c | rc = V2_sync_indirect (inode, |
inode | 284 | fs/minix/fsync.c | static int V2_sync_tindirect(struct inode *inode, unsigned long *tiblock, |
inode | 291 | fs/minix/fsync.c | rc = V2_sync_iblock (inode, tiblock, &tind_bh, wait); |
inode | 296 | fs/minix/fsync.c | rc = V2_sync_dindirect (inode, |
inode | 308 | fs/minix/fsync.c | int V2_minix_sync_file(struct inode * inode, struct file * file) |
inode | 312 | fs/minix/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 313 | fs/minix/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 318 | fs/minix/fsync.c | err |= V2_sync_direct(inode, wait); |
inode | 319 | fs/minix/fsync.c | err |= V2_sync_indirect(inode, |
inode | 320 | fs/minix/fsync.c | (unsigned long *) inode->u.minix_i.u.i2_data + 7, wait); |
inode | 321 | fs/minix/fsync.c | err |= V2_sync_dindirect(inode, |
inode | 322 | fs/minix/fsync.c | (unsigned long *) inode->u.minix_i.u.i2_data + 8, wait); |
inode | 323 | fs/minix/fsync.c | err |= V2_sync_tindirect(inode, |
inode | 324 | fs/minix/fsync.c | (unsigned long *) inode->u.minix_i.u.i2_data + 9, wait); |
inode | 326 | fs/minix/fsync.c | err |= minix_sync_inode (inode); |
inode | 333 | fs/minix/fsync.c | int minix_sync_file(struct inode * inode, struct file * file) |
inode | 335 | fs/minix/fsync.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 336 | fs/minix/fsync.c | return V1_minix_sync_file(inode, file); |
inode | 338 | fs/minix/fsync.c | return V2_minix_sync_file(inode, file); |
inode | 24 | fs/minix/inode.c | void minix_put_inode(struct inode *inode) |
inode | 26 | fs/minix/inode.c | if (inode->i_nlink) |
inode | 28 | fs/minix/inode.c | inode->i_size = 0; |
inode | 29 | fs/minix/inode.c | minix_truncate(inode); |
inode | 30 | fs/minix/inode.c | minix_free_inode(inode); |
inode | 127 | fs/minix/inode.c | struct inode * dir; |
inode | 144 | fs/minix/inode.c | if (de->inode == MINIX_ROOT_INO && strcmp(de->name, ".") == 0) { |
inode | 151 | fs/minix/inode.c | if (de->inode != MINIX_ROOT_INO) |
inode | 325 | fs/minix/inode.c | #define V1_inode_bmap(inode,nr) (((unsigned short *)(inode)->u.minix_i.u.i1_data)[(nr)]) |
inode | 338 | fs/minix/inode.c | static int V1_minix_bmap(struct inode * inode,int block) |
inode | 346 | fs/minix/inode.c | if (block >= (inode->i_sb->u.minix_sb.s_max_size/BLOCK_SIZE)) { |
inode | 351 | fs/minix/inode.c | return V1_inode_bmap(inode,block); |
inode | 354 | fs/minix/inode.c | i = V1_inode_bmap(inode,7); |
inode | 357 | fs/minix/inode.c | return V1_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block); |
inode | 360 | fs/minix/inode.c | i = V1_inode_bmap(inode,8); |
inode | 363 | fs/minix/inode.c | i = V1_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block>>9); |
inode | 366 | fs/minix/inode.c | return V1_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 511); |
inode | 372 | fs/minix/inode.c | #define V2_inode_bmap(inode,nr) (((unsigned long *)(inode)->u.minix_i.u.i2_data)[(nr)]) |
inode | 384 | fs/minix/inode.c | static int V2_minix_bmap(struct inode * inode,int block) |
inode | 392 | fs/minix/inode.c | if (block >= (inode->i_sb->u.minix_sb.s_max_size/BLOCK_SIZE)) { |
inode | 397 | fs/minix/inode.c | return V2_inode_bmap(inode,block); |
inode | 400 | fs/minix/inode.c | i = V2_inode_bmap(inode,7); |
inode | 403 | fs/minix/inode.c | return V2_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block); |
inode | 407 | fs/minix/inode.c | i = V2_inode_bmap(inode,8); |
inode | 410 | fs/minix/inode.c | i = V2_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block >> 8); |
inode | 413 | fs/minix/inode.c | return V2_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 255); |
inode | 416 | fs/minix/inode.c | i = V2_inode_bmap(inode,9); |
inode | 419 | fs/minix/inode.c | i = V2_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block >> 16); |
inode | 422 | fs/minix/inode.c | i = V2_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),(block >> 8) & 255); |
inode | 425 | fs/minix/inode.c | return V2_block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 255); |
inode | 431 | fs/minix/inode.c | int minix_bmap(struct inode * inode,int block) |
inode | 433 | fs/minix/inode.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 434 | fs/minix/inode.c | return V1_minix_bmap(inode, block); |
inode | 436 | fs/minix/inode.c | return V2_minix_bmap(inode, block); |
inode | 442 | fs/minix/inode.c | static struct buffer_head * V1_inode_getblk(struct inode * inode, int nr, |
inode | 449 | fs/minix/inode.c | p = inode->u.minix_i.u.i1_data + nr; |
inode | 453 | fs/minix/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 461 | fs/minix/inode.c | tmp = minix_new_block(inode->i_sb); |
inode | 464 | fs/minix/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 466 | fs/minix/inode.c | minix_free_block(inode->i_sb,tmp); |
inode | 471 | fs/minix/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 472 | fs/minix/inode.c | inode->i_dirt = 1; |
inode | 476 | fs/minix/inode.c | static struct buffer_head * V1_block_getblk(struct inode * inode, |
inode | 509 | fs/minix/inode.c | tmp = minix_new_block(inode->i_sb); |
inode | 516 | fs/minix/inode.c | minix_free_block(inode->i_sb,tmp); |
inode | 526 | fs/minix/inode.c | static struct buffer_head * V1_minix_getblk(struct inode * inode, int block, |
inode | 535 | fs/minix/inode.c | if (block >= inode->i_sb->u.minix_sb.s_max_size/BLOCK_SIZE) { |
inode | 540 | fs/minix/inode.c | return V1_inode_getblk(inode,block,create); |
inode | 543 | fs/minix/inode.c | bh = V1_inode_getblk(inode,7,create); |
inode | 544 | fs/minix/inode.c | return V1_block_getblk(inode, bh, block, create); |
inode | 547 | fs/minix/inode.c | bh = V1_inode_getblk(inode,8,create); |
inode | 548 | fs/minix/inode.c | bh = V1_block_getblk(inode, bh, (block>>9) & 511, create); |
inode | 549 | fs/minix/inode.c | return V1_block_getblk(inode, bh, block & 511, create); |
inode | 555 | fs/minix/inode.c | static struct buffer_head * V2_inode_getblk(struct inode * inode, int nr, |
inode | 562 | fs/minix/inode.c | p = (unsigned long *) inode->u.minix_i.u.i2_data + nr; |
inode | 566 | fs/minix/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 574 | fs/minix/inode.c | tmp = minix_new_block(inode->i_sb); |
inode | 577 | fs/minix/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 579 | fs/minix/inode.c | minix_free_block(inode->i_sb,tmp); |
inode | 584 | fs/minix/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 585 | fs/minix/inode.c | inode->i_dirt = 1; |
inode | 589 | fs/minix/inode.c | static struct buffer_head * V2_block_getblk(struct inode * inode, |
inode | 622 | fs/minix/inode.c | tmp = minix_new_block(inode->i_sb); |
inode | 629 | fs/minix/inode.c | minix_free_block(inode->i_sb,tmp); |
inode | 639 | fs/minix/inode.c | static struct buffer_head * V2_minix_getblk(struct inode * inode, int block, |
inode | 648 | fs/minix/inode.c | if (block >= inode->i_sb->u.minix_sb.s_max_size/BLOCK_SIZE) { |
inode | 653 | fs/minix/inode.c | return V2_inode_getblk(inode,block,create); |
inode | 656 | fs/minix/inode.c | bh = V2_inode_getblk(inode,7,create); |
inode | 657 | fs/minix/inode.c | return V2_block_getblk(inode, bh, block, create); |
inode | 661 | fs/minix/inode.c | bh = V2_inode_getblk(inode,8,create); |
inode | 662 | fs/minix/inode.c | bh = V2_block_getblk(inode, bh, (block>>8) & 255, create); |
inode | 663 | fs/minix/inode.c | return V2_block_getblk(inode, bh, block & 255, create); |
inode | 666 | fs/minix/inode.c | bh = V2_inode_getblk(inode,9,create); |
inode | 667 | fs/minix/inode.c | bh = V2_block_getblk(inode, bh, (block >> 16) & 255, create); |
inode | 668 | fs/minix/inode.c | bh = V2_block_getblk(inode, bh, (block >> 8) & 255, create); |
inode | 669 | fs/minix/inode.c | return V2_block_getblk(inode, bh, block & 255, create); |
inode | 675 | fs/minix/inode.c | struct buffer_head * minix_getblk(struct inode * inode, int block, int create) |
inode | 677 | fs/minix/inode.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 678 | fs/minix/inode.c | return V1_minix_getblk(inode,block,create); |
inode | 680 | fs/minix/inode.c | return V2_minix_getblk(inode,block,create); |
inode | 683 | fs/minix/inode.c | struct buffer_head * minix_bread(struct inode * inode, int block, int create) |
inode | 687 | fs/minix/inode.c | bh = minix_getblk(inode,block,create); |
inode | 701 | fs/minix/inode.c | static void V1_minix_read_inode(struct inode * inode) |
inode | 707 | fs/minix/inode.c | ino = inode->i_ino; |
inode | 708 | fs/minix/inode.c | inode->i_op = NULL; |
inode | 709 | fs/minix/inode.c | inode->i_mode = 0; |
inode | 710 | fs/minix/inode.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 713 | fs/minix/inode.c | kdevname(inode->i_dev), ino); |
inode | 716 | fs/minix/inode.c | block = 2 + inode->i_sb->u.minix_sb.s_imap_blocks + |
inode | 717 | fs/minix/inode.c | inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 719 | fs/minix/inode.c | if (!(bh=bread(inode->i_dev,block, BLOCK_SIZE))) { |
inode | 721 | fs/minix/inode.c | "%s\n", kdevname(inode->i_dev)); |
inode | 726 | fs/minix/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 727 | fs/minix/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 728 | fs/minix/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 729 | fs/minix/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 730 | fs/minix/inode.c | inode->i_size = raw_inode->i_size; |
inode | 731 | fs/minix/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = raw_inode->i_time; |
inode | 732 | fs/minix/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 733 | fs/minix/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 734 | fs/minix/inode.c | inode->i_rdev = to_kdev_t(raw_inode->i_zone[0]); |
inode | 736 | fs/minix/inode.c | inode->u.minix_i.u.i1_data[block] = raw_inode->i_zone[block]; |
inode | 738 | fs/minix/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 739 | fs/minix/inode.c | inode->i_op = &minix_file_inode_operations; |
inode | 740 | fs/minix/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 741 | fs/minix/inode.c | inode->i_op = &minix_dir_inode_operations; |
inode | 742 | fs/minix/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 743 | fs/minix/inode.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 744 | fs/minix/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 745 | fs/minix/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 746 | fs/minix/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 747 | fs/minix/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 748 | fs/minix/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 749 | fs/minix/inode.c | init_fifo(inode); |
inode | 755 | fs/minix/inode.c | static void V2_minix_read_inode(struct inode * inode) |
inode | 761 | fs/minix/inode.c | ino = inode->i_ino; |
inode | 762 | fs/minix/inode.c | inode->i_op = NULL; |
inode | 763 | fs/minix/inode.c | inode->i_mode = 0; |
inode | 764 | fs/minix/inode.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 767 | fs/minix/inode.c | kdevname(inode->i_dev), ino); |
inode | 770 | fs/minix/inode.c | block = 2 + inode->i_sb->u.minix_sb.s_imap_blocks + |
inode | 771 | fs/minix/inode.c | inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 773 | fs/minix/inode.c | if (!(bh=bread(inode->i_dev,block, BLOCK_SIZE))) { |
inode | 775 | fs/minix/inode.c | "%s\n", kdevname(inode->i_dev)); |
inode | 780 | fs/minix/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 781 | fs/minix/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 782 | fs/minix/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 783 | fs/minix/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 784 | fs/minix/inode.c | inode->i_size = raw_inode->i_size; |
inode | 785 | fs/minix/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 786 | fs/minix/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 787 | fs/minix/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 788 | fs/minix/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 789 | fs/minix/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 790 | fs/minix/inode.c | inode->i_rdev = to_kdev_t(raw_inode->i_zone[0]); |
inode | 792 | fs/minix/inode.c | inode->u.minix_i.u.i2_data[block] = raw_inode->i_zone[block]; |
inode | 794 | fs/minix/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 795 | fs/minix/inode.c | inode->i_op = &minix_file_inode_operations; |
inode | 796 | fs/minix/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 797 | fs/minix/inode.c | inode->i_op = &minix_dir_inode_operations; |
inode | 798 | fs/minix/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 799 | fs/minix/inode.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 800 | fs/minix/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 801 | fs/minix/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 802 | fs/minix/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 803 | fs/minix/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 804 | fs/minix/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 805 | fs/minix/inode.c | init_fifo(inode); |
inode | 811 | fs/minix/inode.c | void minix_read_inode(struct inode * inode) |
inode | 813 | fs/minix/inode.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 814 | fs/minix/inode.c | V1_minix_read_inode(inode); |
inode | 816 | fs/minix/inode.c | V2_minix_read_inode(inode); |
inode | 822 | fs/minix/inode.c | static struct buffer_head * V1_minix_update_inode(struct inode * inode) |
inode | 828 | fs/minix/inode.c | ino = inode->i_ino; |
inode | 829 | fs/minix/inode.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 832 | fs/minix/inode.c | kdevname(inode->i_dev), ino); |
inode | 833 | fs/minix/inode.c | inode->i_dirt = 0; |
inode | 836 | fs/minix/inode.c | block = 2 + inode->i_sb->u.minix_sb.s_imap_blocks + inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 838 | fs/minix/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) { |
inode | 840 | fs/minix/inode.c | inode->i_dirt = 0; |
inode | 845 | fs/minix/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 846 | fs/minix/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 847 | fs/minix/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 848 | fs/minix/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 849 | fs/minix/inode.c | raw_inode->i_size = inode->i_size; |
inode | 850 | fs/minix/inode.c | raw_inode->i_time = inode->i_mtime; |
inode | 851 | fs/minix/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 852 | fs/minix/inode.c | raw_inode->i_zone[0] = kdev_t_to_nr(inode->i_rdev); |
inode | 854 | fs/minix/inode.c | raw_inode->i_zone[block] = inode->u.minix_i.u.i1_data[block]; |
inode | 855 | fs/minix/inode.c | inode->i_dirt=0; |
inode | 863 | fs/minix/inode.c | static struct buffer_head * V2_minix_update_inode(struct inode * inode) |
inode | 869 | fs/minix/inode.c | ino = inode->i_ino; |
inode | 870 | fs/minix/inode.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 873 | fs/minix/inode.c | kdevname(inode->i_dev), ino); |
inode | 874 | fs/minix/inode.c | inode->i_dirt = 0; |
inode | 877 | fs/minix/inode.c | block = 2 + inode->i_sb->u.minix_sb.s_imap_blocks + inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 879 | fs/minix/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) { |
inode | 881 | fs/minix/inode.c | inode->i_dirt = 0; |
inode | 886 | fs/minix/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 887 | fs/minix/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 888 | fs/minix/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 889 | fs/minix/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 890 | fs/minix/inode.c | raw_inode->i_size = inode->i_size; |
inode | 891 | fs/minix/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 892 | fs/minix/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 893 | fs/minix/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 894 | fs/minix/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 895 | fs/minix/inode.c | raw_inode->i_zone[0] = kdev_t_to_nr(inode->i_rdev); |
inode | 897 | fs/minix/inode.c | raw_inode->i_zone[block] = inode->u.minix_i.u.i2_data[block]; |
inode | 898 | fs/minix/inode.c | inode->i_dirt=0; |
inode | 903 | fs/minix/inode.c | struct buffer_head *minix_update_inode(struct inode *inode) |
inode | 905 | fs/minix/inode.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 906 | fs/minix/inode.c | return V1_minix_update_inode(inode); |
inode | 908 | fs/minix/inode.c | return V2_minix_update_inode(inode); |
inode | 911 | fs/minix/inode.c | void minix_write_inode(struct inode * inode) |
inode | 915 | fs/minix/inode.c | bh = minix_update_inode(inode); |
inode | 919 | fs/minix/inode.c | int minix_sync_inode(struct inode * inode) |
inode | 924 | fs/minix/inode.c | bh = minix_update_inode(inode); |
inode | 933 | fs/minix/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 48 | fs/minix/namei.c | if (!de->inode || len > info->s_namelen) |
inode | 64 | fs/minix/namei.c | static struct buffer_head * minix_find_entry(struct inode * dir, |
inode | 107 | fs/minix/namei.c | int minix_lookup(struct inode * dir,const char * name, int len, |
inode | 108 | fs/minix/namei.c | struct inode ** result) |
inode | 125 | fs/minix/namei.c | ino = de->inode; |
inode | 145 | fs/minix/namei.c | static int minix_add_entry(struct inode * dir, |
inode | 181 | fs/minix/namei.c | de->inode = 0; |
inode | 185 | fs/minix/namei.c | if (de->inode) { |
inode | 211 | fs/minix/namei.c | int minix_create(struct inode * dir,const char * name, int len, int mode, |
inode | 212 | fs/minix/namei.c | struct inode ** result) |
inode | 215 | fs/minix/namei.c | struct inode * inode; |
inode | 222 | fs/minix/namei.c | inode = minix_new_inode(dir); |
inode | 223 | fs/minix/namei.c | if (!inode) { |
inode | 227 | fs/minix/namei.c | inode->i_op = &minix_file_inode_operations; |
inode | 228 | fs/minix/namei.c | inode->i_mode = mode; |
inode | 229 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 232 | fs/minix/namei.c | inode->i_nlink--; |
inode | 233 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 234 | fs/minix/namei.c | iput(inode); |
inode | 238 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 242 | fs/minix/namei.c | *result = inode; |
inode | 246 | fs/minix/namei.c | int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
inode | 249 | fs/minix/namei.c | struct inode * inode; |
inode | 261 | fs/minix/namei.c | inode = minix_new_inode(dir); |
inode | 262 | fs/minix/namei.c | if (!inode) { |
inode | 266 | fs/minix/namei.c | inode->i_uid = current->fsuid; |
inode | 267 | fs/minix/namei.c | inode->i_mode = mode; |
inode | 268 | fs/minix/namei.c | inode->i_op = NULL; |
inode | 269 | fs/minix/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 270 | fs/minix/namei.c | inode->i_op = &minix_file_inode_operations; |
inode | 271 | fs/minix/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 272 | fs/minix/namei.c | inode->i_op = &minix_dir_inode_operations; |
inode | 274 | fs/minix/namei.c | inode->i_mode |= S_ISGID; |
inode | 276 | fs/minix/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 277 | fs/minix/namei.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 278 | fs/minix/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 279 | fs/minix/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 280 | fs/minix/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 281 | fs/minix/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 282 | fs/minix/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 283 | fs/minix/namei.c | init_fifo(inode); |
inode | 285 | fs/minix/namei.c | inode->i_rdev = to_kdev_t(rdev); |
inode | 286 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 289 | fs/minix/namei.c | inode->i_nlink--; |
inode | 290 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 291 | fs/minix/namei.c | iput(inode); |
inode | 295 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 299 | fs/minix/namei.c | iput(inode); |
inode | 303 | fs/minix/namei.c | int minix_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 306 | fs/minix/namei.c | struct inode * inode; |
inode | 326 | fs/minix/namei.c | inode = minix_new_inode(dir); |
inode | 327 | fs/minix/namei.c | if (!inode) { |
inode | 331 | fs/minix/namei.c | inode->i_op = &minix_dir_inode_operations; |
inode | 332 | fs/minix/namei.c | inode->i_size = 2 * info->s_dirsize; |
inode | 333 | fs/minix/namei.c | dir_block = minix_bread(inode,0,1); |
inode | 336 | fs/minix/namei.c | inode->i_nlink--; |
inode | 337 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 338 | fs/minix/namei.c | iput(inode); |
inode | 342 | fs/minix/namei.c | de->inode=inode->i_ino; |
inode | 345 | fs/minix/namei.c | de->inode = dir->i_ino; |
inode | 347 | fs/minix/namei.c | inode->i_nlink = 2; |
inode | 350 | fs/minix/namei.c | inode->i_mode = S_IFDIR | (mode & 0777 & ~current->fs->umask); |
inode | 352 | fs/minix/namei.c | inode->i_mode |= S_ISGID; |
inode | 353 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 357 | fs/minix/namei.c | inode->i_nlink=0; |
inode | 358 | fs/minix/namei.c | iput(inode); |
inode | 361 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 366 | fs/minix/namei.c | iput(inode); |
inode | 374 | fs/minix/namei.c | static int empty_dir(struct inode * inode) |
inode | 381 | fs/minix/namei.c | if (!inode || !inode->i_sb) |
inode | 383 | fs/minix/namei.c | info = &inode->i_sb->u.minix_sb; |
inode | 387 | fs/minix/namei.c | if (inode->i_size & (info->s_dirsize-1)) |
inode | 389 | fs/minix/namei.c | if (inode->i_size < offset) |
inode | 391 | fs/minix/namei.c | bh = minix_bread(inode,0,0); |
inode | 395 | fs/minix/namei.c | if (!de->inode || strcmp(de->name,".")) |
inode | 398 | fs/minix/namei.c | if (!de->inode || strcmp(de->name,"..")) |
inode | 400 | fs/minix/namei.c | while (block*BLOCK_SIZE+offset < inode->i_size) { |
inode | 402 | fs/minix/namei.c | bh = minix_bread(inode,block,0); |
inode | 410 | fs/minix/namei.c | if (de->inode) { |
inode | 426 | fs/minix/namei.c | kdevname(inode->i_dev)); |
inode | 430 | fs/minix/namei.c | int minix_rmdir(struct inode * dir, const char * name, int len) |
inode | 433 | fs/minix/namei.c | struct inode * inode; |
inode | 437 | fs/minix/namei.c | inode = NULL; |
inode | 443 | fs/minix/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 446 | fs/minix/namei.c | current->fsuid != inode->i_uid && |
inode | 449 | fs/minix/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 451 | fs/minix/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 453 | fs/minix/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 457 | fs/minix/namei.c | if (!empty_dir(inode)) { |
inode | 461 | fs/minix/namei.c | if (de->inode != inode->i_ino) { |
inode | 465 | fs/minix/namei.c | if (inode->i_count > 1) { |
inode | 469 | fs/minix/namei.c | if (inode->i_nlink != 2) |
inode | 470 | fs/minix/namei.c | printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); |
inode | 471 | fs/minix/namei.c | de->inode = 0; |
inode | 474 | fs/minix/namei.c | inode->i_nlink=0; |
inode | 475 | fs/minix/namei.c | inode->i_dirt=1; |
inode | 476 | fs/minix/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 482 | fs/minix/namei.c | iput(inode); |
inode | 487 | fs/minix/namei.c | int minix_unlink(struct inode * dir, const char * name, int len) |
inode | 490 | fs/minix/namei.c | struct inode * inode; |
inode | 496 | fs/minix/namei.c | inode = NULL; |
inode | 500 | fs/minix/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 503 | fs/minix/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 505 | fs/minix/namei.c | if (de->inode != inode->i_ino) { |
inode | 506 | fs/minix/namei.c | iput(inode); |
inode | 513 | fs/minix/namei.c | current->fsuid != inode->i_uid && |
inode | 516 | fs/minix/namei.c | if (de->inode != inode->i_ino) { |
inode | 520 | fs/minix/namei.c | if (!inode->i_nlink) { |
inode | 522 | fs/minix/namei.c | kdevname(inode->i_dev), |
inode | 523 | fs/minix/namei.c | inode->i_ino, inode->i_nlink); |
inode | 524 | fs/minix/namei.c | inode->i_nlink=1; |
inode | 526 | fs/minix/namei.c | de->inode = 0; |
inode | 531 | fs/minix/namei.c | inode->i_nlink--; |
inode | 532 | fs/minix/namei.c | inode->i_ctime = dir->i_ctime; |
inode | 533 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 537 | fs/minix/namei.c | iput(inode); |
inode | 542 | fs/minix/namei.c | int minix_symlink(struct inode * dir, const char * name, int len, const char * symname) |
inode | 545 | fs/minix/namei.c | struct inode * inode = NULL; |
inode | 550 | fs/minix/namei.c | if (!(inode = minix_new_inode(dir))) { |
inode | 554 | fs/minix/namei.c | inode->i_mode = S_IFLNK | 0777; |
inode | 555 | fs/minix/namei.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 556 | fs/minix/namei.c | name_block = minix_bread(inode,0,1); |
inode | 559 | fs/minix/namei.c | inode->i_nlink--; |
inode | 560 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 561 | fs/minix/namei.c | iput(inode); |
inode | 570 | fs/minix/namei.c | inode->i_size = i; |
inode | 571 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 574 | fs/minix/namei.c | inode->i_nlink--; |
inode | 575 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 576 | fs/minix/namei.c | iput(inode); |
inode | 583 | fs/minix/namei.c | inode->i_nlink--; |
inode | 584 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 585 | fs/minix/namei.c | iput(inode); |
inode | 589 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 593 | fs/minix/namei.c | iput(inode); |
inode | 597 | fs/minix/namei.c | int minix_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
inode | 626 | fs/minix/namei.c | de->inode = oldinode->i_ino; |
inode | 637 | fs/minix/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 662 | fs/minix/namei.c | (((struct minix_dir_entry *) ((buffer)+info->s_dirsize))->inode) |
inode | 674 | fs/minix/namei.c | static int do_minix_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 675 | fs/minix/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 677 | fs/minix/namei.c | struct inode * old_inode, * new_inode; |
inode | 700 | fs/minix/namei.c | old_inode = __iget(old_dir->i_sb, old_de->inode,0); /* don't cross mnt-points */ |
inode | 710 | fs/minix/namei.c | new_inode = __iget(new_dir->i_sb, new_de->inode, 0); |
inode | 762 | fs/minix/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 764 | fs/minix/namei.c | if (new_de->inode && !new_inode) |
inode | 766 | fs/minix/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 769 | fs/minix/namei.c | old_de->inode = 0; |
inode | 770 | fs/minix/namei.c | new_de->inode = old_inode->i_ino; |
inode | 818 | fs/minix/namei.c | int minix_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 819 | fs/minix/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 17 | fs/minix/symlink.c | static int minix_readlink(struct inode *, char *, int); |
inode | 18 | fs/minix/symlink.c | static int minix_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 43 | fs/minix/symlink.c | static int minix_follow_link(struct inode * dir, struct inode * inode, |
inode | 44 | fs/minix/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 54 | fs/minix/symlink.c | if (!inode) { |
inode | 58 | fs/minix/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 60 | fs/minix/symlink.c | *res_inode = inode; |
inode | 64 | fs/minix/symlink.c | iput(inode); |
inode | 68 | fs/minix/symlink.c | if (!(bh = minix_bread(inode, 0, 0))) { |
inode | 69 | fs/minix/symlink.c | iput(inode); |
inode | 73 | fs/minix/symlink.c | iput(inode); |
inode | 81 | fs/minix/symlink.c | static int minix_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 87 | fs/minix/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 88 | fs/minix/symlink.c | iput(inode); |
inode | 93 | fs/minix/symlink.c | bh = minix_bread(inode, 0, 0); |
inode | 94 | fs/minix/symlink.c | iput(inode); |
inode | 16 | fs/minix/truncate.c | #define DIRECT_BLOCK ((inode->i_size + 1023) >> 10) |
inode | 38 | fs/minix/truncate.c | static int V1_trunc_direct(struct inode * inode) |
inode | 47 | fs/minix/truncate.c | p = i + inode->u.minix_i.u.i1_data; |
inode | 50 | fs/minix/truncate.c | bh = get_hash_table(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 61 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 66 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 71 | fs/minix/truncate.c | static int V1_trunc_indirect(struct inode * inode, int offset, unsigned short * p) |
inode | 82 | fs/minix/truncate.c | ind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 101 | fs/minix/truncate.c | bh = get_hash_table(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 114 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 126 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 132 | fs/minix/truncate.c | static int V1_trunc_dindirect(struct inode * inode, int offset, unsigned short *p) |
inode | 141 | fs/minix/truncate.c | dind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 157 | fs/minix/truncate.c | retry |= V1_trunc_indirect(inode,offset+(i<<9),dind); |
inode | 170 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 171 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 177 | fs/minix/truncate.c | void V1_minix_truncate(struct inode * inode) |
inode | 181 | fs/minix/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 182 | fs/minix/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 185 | fs/minix/truncate.c | retry = V1_trunc_direct(inode); |
inode | 186 | fs/minix/truncate.c | retry |= V1_trunc_indirect(inode, 7, inode->u.minix_i.u.i1_data + 7); |
inode | 187 | fs/minix/truncate.c | retry |= V1_trunc_dindirect(inode, 7+512, inode->u.minix_i.u.i1_data + 8); |
inode | 193 | fs/minix/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 194 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 200 | fs/minix/truncate.c | static int V2_trunc_direct(struct inode * inode) |
inode | 209 | fs/minix/truncate.c | p = (unsigned long *) inode->u.minix_i.u.i2_data + i; |
inode | 212 | fs/minix/truncate.c | bh = get_hash_table(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 223 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 228 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 233 | fs/minix/truncate.c | static int V2_trunc_indirect(struct inode * inode, int offset, unsigned long * p) |
inode | 244 | fs/minix/truncate.c | ind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 263 | fs/minix/truncate.c | bh = get_hash_table(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 276 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 288 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 294 | fs/minix/truncate.c | static int V2_trunc_dindirect(struct inode * inode, int offset, unsigned long *p) |
inode | 303 | fs/minix/truncate.c | dind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 319 | fs/minix/truncate.c | retry |= V2_trunc_indirect(inode,offset+(i<<8),dind); |
inode | 332 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 333 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 339 | fs/minix/truncate.c | static int V2_trunc_tindirect(struct inode * inode, int offset, unsigned long * p) |
inode | 348 | fs/minix/truncate.c | tind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 364 | fs/minix/truncate.c | retry |= V2_trunc_dindirect(inode,offset+(i<<8),tind); |
inode | 377 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 378 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 384 | fs/minix/truncate.c | static void V2_minix_truncate(struct inode * inode) |
inode | 388 | fs/minix/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 389 | fs/minix/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 392 | fs/minix/truncate.c | retry = V2_trunc_direct(inode); |
inode | 393 | fs/minix/truncate.c | retry |= V2_trunc_indirect(inode,7, |
inode | 394 | fs/minix/truncate.c | (unsigned long *) inode->u.minix_i.u.i2_data + 7); |
inode | 395 | fs/minix/truncate.c | retry |= V2_trunc_dindirect(inode, 7+256, |
inode | 396 | fs/minix/truncate.c | (unsigned long *) inode->u.minix_i.u.i2_data + 8); |
inode | 397 | fs/minix/truncate.c | retry |= V2_trunc_tindirect(inode, 7+256+256*256, |
inode | 398 | fs/minix/truncate.c | (unsigned long *) inode->u.minix_i.u.i2_data + 9); |
inode | 404 | fs/minix/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 405 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 411 | fs/minix/truncate.c | void minix_truncate(struct inode * inode) |
inode | 413 | fs/minix/truncate.c | if (INODE_VERSION(inode) == MINIX_V1) |
inode | 414 | fs/minix/truncate.c | V1_minix_truncate(inode); |
inode | 416 | fs/minix/truncate.c | V2_minix_truncate(inode); |
inode | 149 | fs/msdos/namei.c | static int msdos_find(struct inode *dir,const char *name,int len, |
inode | 176 | fs/msdos/namei.c | int msdos_lookup(struct inode *dir,const char *name,int len, |
inode | 177 | fs/msdos/namei.c | struct inode **result) |
inode | 183 | fs/msdos/namei.c | struct inode *next; |
inode | 256 | fs/msdos/namei.c | static int msdos_create_entry(struct inode *dir, const char *name,int len, |
inode | 257 | fs/msdos/namei.c | int is_dir, int is_hid, struct inode **result) |
inode | 295 | fs/msdos/namei.c | int msdos_create(struct inode *dir,const char *name,int len,int mode, |
inode | 296 | fs/msdos/namei.c | struct inode **result) |
inode | 357 | fs/msdos/namei.c | static int msdos_empty(struct inode *dir) |
inode | 383 | fs/msdos/namei.c | int msdos_rmdir(struct inode *dir,const char *name,int len) |
inode | 389 | fs/msdos/namei.c | struct inode *inode; |
inode | 392 | fs/msdos/namei.c | inode = NULL; |
inode | 398 | fs/msdos/namei.c | if (!(inode = iget(dir->i_sb,ino))) goto rmdir_done; |
inode | 400 | fs/msdos/namei.c | if (!S_ISDIR(inode->i_mode)) goto rmdir_done; |
inode | 402 | fs/msdos/namei.c | if (dir->i_dev != inode->i_dev || dir == inode) |
inode | 404 | fs/msdos/namei.c | res = msdos_empty(inode); |
inode | 407 | fs/msdos/namei.c | inode->i_nlink = 0; |
inode | 408 | fs/msdos/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 410 | fs/msdos/namei.c | inode->i_dirt = dir->i_dirt = 1; |
inode | 417 | fs/msdos/namei.c | iput(inode); |
inode | 422 | fs/msdos/namei.c | int msdos_mkdir(struct inode *dir,const char *name,int len,int mode) |
inode | 427 | fs/msdos/namei.c | struct inode *inode,*dot; |
inode | 446 | fs/msdos/namei.c | &inode)) < 0) { |
inode | 452 | fs/msdos/namei.c | inode->i_nlink = 2; /* no need to mark them dirty */ |
inode | 453 | fs/msdos/namei.c | MSDOS_I(inode)->i_busy = 1; /* prevent lookups */ |
inode | 454 | fs/msdos/namei.c | if ((res = fat_add_cluster(inode)) < 0) goto mkdir_error; |
inode | 455 | fs/msdos/namei.c | if ((res = msdos_create_entry(inode,MSDOS_DOT,1,1,0,&dot)) < 0) |
inode | 457 | fs/msdos/namei.c | dot->i_size = inode->i_size; /* doesn't grow in the 2nd create_entry */ |
inode | 458 | fs/msdos/namei.c | MSDOS_I(dot)->i_start = MSDOS_I(inode)->i_start; |
inode | 459 | fs/msdos/namei.c | dot->i_nlink = inode->i_nlink; |
inode | 462 | fs/msdos/namei.c | if ((res = msdos_create_entry(inode,MSDOS_DOTDOT,2,1,0,&dot)) < 0) |
inode | 469 | fs/msdos/namei.c | MSDOS_I(inode)->i_busy = 0; |
inode | 471 | fs/msdos/namei.c | iput(inode); |
inode | 475 | fs/msdos/namei.c | iput(inode); |
inode | 484 | fs/msdos/namei.c | struct inode *dir, |
inode | 493 | fs/msdos/namei.c | struct inode *inode; |
inode | 496 | fs/msdos/namei.c | inode = NULL; |
inode | 499 | fs/msdos/namei.c | if (!(inode = iget(dir->i_sb,ino))) { |
inode | 503 | fs/msdos/namei.c | if (!S_ISREG(inode->i_mode) && nospc){ |
inode | 507 | fs/msdos/namei.c | if (IS_IMMUTABLE(inode)){ |
inode | 511 | fs/msdos/namei.c | inode->i_nlink = 0; |
inode | 512 | fs/msdos/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 513 | fs/msdos/namei.c | MSDOS_I(inode)->i_busy = 1; |
inode | 514 | fs/msdos/namei.c | inode->i_dirt = dir->i_dirt = 1; |
inode | 519 | fs/msdos/namei.c | iput(inode); |
inode | 525 | fs/msdos/namei.c | int msdos_unlink(struct inode *dir,const char *name,int len) |
inode | 531 | fs/msdos/namei.c | int msdos_unlink_umsdos(struct inode *dir,const char *name,int len) |
inode | 537 | fs/msdos/namei.c | static int rename_same_dir(struct inode *old_dir,char *old_name,int old_len, |
inode | 538 | fs/msdos/namei.c | struct inode *new_dir,char *new_name,int new_len, |
inode | 545 | fs/msdos/namei.c | struct inode *new_inode,*old_inode; |
inode | 602 | fs/msdos/namei.c | static int rename_diff_dir(struct inode *old_dir,char *old_name,int old_len, |
inode | 603 | fs/msdos/namei.c | struct inode *new_dir,char *new_name,int new_len, |
inode | 610 | fs/msdos/namei.c | struct inode *old_inode,*new_inode,*free_inode,*dotdot_inode,*walk; |
inode | 737 | fs/msdos/namei.c | int msdos_rename(struct inode *old_dir,const char *old_name,int old_len, |
inode | 738 | fs/msdos/namei.c | struct inode *new_dir,const char *new_name,int new_len) |
inode | 796 | fs/msdos/namei.c | void msdos_read_inode(struct inode *inode) |
inode | 798 | fs/msdos/namei.c | fat_read_inode(inode, &msdos_dir_inode_operations); |
inode | 99 | fs/namei.c | int permission(struct inode * inode,int mask) |
inode | 101 | fs/namei.c | int mode = inode->i_mode; |
inode | 103 | fs/namei.c | if (inode->i_op && inode->i_op->permission) |
inode | 104 | fs/namei.c | return inode->i_op->permission(inode, mask); |
inode | 105 | fs/namei.c | else if ((mask & S_IWOTH) && IS_IMMUTABLE(inode)) |
inode | 107 | fs/namei.c | else if (current->fsuid == inode->i_uid) |
inode | 109 | fs/namei.c | else if (in_group_p(inode->i_gid)) |
inode | 123 | fs/namei.c | int get_write_access(struct inode * inode) |
inode | 127 | fs/namei.c | if ((inode->i_count > 1) && S_ISREG(inode->i_mode)) /* shortcut */ |
inode | 133 | fs/namei.c | if (inode != mpnt->vm_inode) |
inode | 139 | fs/namei.c | inode->i_writecount++; |
inode | 143 | fs/namei.c | void put_write_access(struct inode * inode) |
inode | 145 | fs/namei.c | inode->i_writecount--; |
inode | 153 | fs/namei.c | int lookup(struct inode * dir,const char * name, int len, |
inode | 154 | fs/namei.c | struct inode ** result) |
inode | 191 | fs/namei.c | int follow_link(struct inode * dir, struct inode * inode, |
inode | 192 | fs/namei.c | int flag, int mode, struct inode ** res_inode) |
inode | 194 | fs/namei.c | if (!dir || !inode) { |
inode | 196 | fs/namei.c | iput(inode); |
inode | 200 | fs/namei.c | if (!inode->i_op || !inode->i_op->follow_link) { |
inode | 202 | fs/namei.c | *res_inode = inode; |
inode | 205 | fs/namei.c | return inode->i_op->follow_link(dir,inode,flag,mode,res_inode); |
inode | 215 | fs/namei.c | struct inode * base, struct inode **res_inode) |
inode | 220 | fs/namei.c | struct inode * inode; |
inode | 240 | fs/namei.c | error = lookup(base, thisname, len, &inode); |
inode | 245 | fs/namei.c | error = follow_link(base,inode,0,0,&base); |
inode | 259 | fs/namei.c | static int _namei(const char * pathname, struct inode * base, |
inode | 260 | fs/namei.c | int follow_links, struct inode ** res_inode) |
inode | 264 | fs/namei.c | struct inode * inode; |
inode | 271 | fs/namei.c | error = lookup(base, basename, namelen, &inode); |
inode | 277 | fs/namei.c | error = follow_link(base, inode, 0, 0, &inode); |
inode | 282 | fs/namei.c | *res_inode = inode; |
inode | 286 | fs/namei.c | int lnamei(const char *pathname, struct inode **res_inode) |
inode | 306 | fs/namei.c | int namei(const char *pathname, struct inode **res_inode) |
inode | 333 | fs/namei.c | struct inode ** res_inode, struct inode * base) |
inode | 337 | fs/namei.c | struct inode * dir, *inode; |
inode | 360 | fs/namei.c | error = lookup(dir, basename, namelen, &inode); |
inode | 363 | fs/namei.c | iput(inode); |
inode | 383 | fs/namei.c | error = lookup(dir, basename, namelen, &inode); |
inode | 388 | fs/namei.c | error = follow_link(dir,inode,flag,mode,&inode); |
inode | 391 | fs/namei.c | if (S_ISDIR(inode->i_mode) && (flag & 2)) { |
inode | 392 | fs/namei.c | iput(inode); |
inode | 395 | fs/namei.c | if ((error = permission(inode,ACC_MODE(flag))) != 0) { |
inode | 396 | fs/namei.c | iput(inode); |
inode | 399 | fs/namei.c | if (S_ISFIFO(inode->i_mode) || S_ISSOCK(inode->i_mode)) { |
inode | 409 | fs/namei.c | else if (S_ISBLK(inode->i_mode) || S_ISCHR(inode->i_mode)) { |
inode | 410 | fs/namei.c | if (IS_NODEV(inode)) { |
inode | 411 | fs/namei.c | iput(inode); |
inode | 416 | fs/namei.c | if (IS_RDONLY(inode) && (flag & 2)) { |
inode | 417 | fs/namei.c | iput(inode); |
inode | 424 | fs/namei.c | if (IS_APPEND(inode) && ((flag & FMODE_WRITE) && !(flag & O_APPEND))) { |
inode | 425 | fs/namei.c | iput(inode); |
inode | 429 | fs/namei.c | if ((error = get_write_access(inode))) { |
inode | 430 | fs/namei.c | iput(inode); |
inode | 436 | fs/namei.c | error = locks_verify_locked(inode); |
inode | 438 | fs/namei.c | iput(inode); |
inode | 441 | fs/namei.c | if (inode->i_sb && inode->i_sb->dq_op) |
inode | 442 | fs/namei.c | inode->i_sb->dq_op->initialize(inode, -1); |
inode | 444 | fs/namei.c | error = do_truncate(inode, 0); |
inode | 445 | fs/namei.c | put_write_access(inode); |
inode | 447 | fs/namei.c | iput(inode); |
inode | 452 | fs/namei.c | if (inode->i_sb && inode->i_sb->dq_op) |
inode | 453 | fs/namei.c | inode->i_sb->dq_op->initialize(inode, -1); |
inode | 454 | fs/namei.c | *res_inode = inode; |
inode | 462 | fs/namei.c | struct inode * dir; |
inode | 522 | fs/namei.c | struct inode * dir; |
inode | 570 | fs/namei.c | struct inode * dir; |
inode | 620 | fs/namei.c | struct inode * dir; |
inode | 668 | fs/namei.c | struct inode * dir; |
inode | 718 | fs/namei.c | static int do_link(struct inode * oldinode, const char * newname) |
inode | 720 | fs/namei.c | struct inode * dir; |
inode | 776 | fs/namei.c | struct inode * oldinode; |
inode | 793 | fs/namei.c | struct inode * old_dir, * new_dir; |
inode | 26 | fs/ncpfs/dir.c | ncp_dir_read(struct inode *inode, struct file *filp, char *buf, int count); |
inode | 29 | fs/ncpfs/dir.c | ncp_readdir(struct inode *inode, struct file *filp, |
inode | 37 | fs/ncpfs/dir.c | ncp_do_readdir(struct ncp_server *server, struct inode *dir, int fpos, |
inode | 40 | fs/ncpfs/dir.c | static struct inode * |
inode | 41 | fs/ncpfs/dir.c | ncp_iget(struct inode *dir, struct nw_file_info *finfo); |
inode | 44 | fs/ncpfs/dir.c | ncp_find_dir_inode(struct inode *dir, const char *name); |
inode | 47 | fs/ncpfs/dir.c | ncp_lookup(struct inode *dir, const char *__name, |
inode | 48 | fs/ncpfs/dir.c | int len, struct inode **result); |
inode | 51 | fs/ncpfs/dir.c | ncp_create(struct inode *dir, const char *name, int len, int mode, |
inode | 52 | fs/ncpfs/dir.c | struct inode **result); |
inode | 55 | fs/ncpfs/dir.c | ncp_mkdir(struct inode *dir, const char *name, int len, int mode); |
inode | 58 | fs/ncpfs/dir.c | ncp_rmdir(struct inode *dir, const char *name, int len); |
inode | 61 | fs/ncpfs/dir.c | ncp_unlink(struct inode *dir, const char *name, int len); |
inode | 64 | fs/ncpfs/dir.c | ncp_rename(struct inode *old_dir, const char *old_name, int old_len, |
inode | 65 | fs/ncpfs/dir.c | struct inode *new_dir, const char *new_name, int new_len); |
inode | 148 | fs/ncpfs/dir.c | ncp_is_server_root(struct inode *inode) |
inode | 150 | fs/ncpfs/dir.c | struct ncp_server *s = NCP_SERVER(inode); |
inode | 153 | fs/ncpfs/dir.c | && (inode->i_ino == ncp_info_ino(s, &(s->root)))); |
inode | 157 | fs/ncpfs/dir.c | ncp_find_inode(struct inode *inode) |
inode | 159 | fs/ncpfs/dir.c | struct ncp_server *server = NCP_SERVER(inode); |
inode | 163 | fs/ncpfs/dir.c | ino_t ino = inode->i_ino; |
inode | 181 | fs/ncpfs/dir.c | ncp_dir_read(struct inode *inode, struct file *filp, char *buf, int count) |
inode | 211 | fs/ncpfs/dir.c | ncp_readdir(struct inode *inode, struct file *filp, |
inode | 218 | fs/ncpfs/dir.c | struct ncp_server *server = NCP_SERVER(inode); |
inode | 219 | fs/ncpfs/dir.c | struct ncp_inode_info *dir = NCP_INOP(inode); |
inode | 223 | fs/ncpfs/dir.c | inode->i_ino, c_ino); |
inode | 225 | fs/ncpfs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 252 | fs/ncpfs/dir.c | ncp_invalid_dir_cache(inode); |
inode | 271 | fs/ncpfs/dir.c | if ((inode->i_dev == c_dev) && (inode->i_ino == c_ino)) |
inode | 294 | fs/ncpfs/dir.c | if (ncp_is_server_root(inode)) |
inode | 303 | fs/ncpfs/dir.c | entries = ncp_do_readdir(server, inode, filp->f_pos, |
inode | 320 | fs/ncpfs/dir.c | c_dev = inode->i_dev; |
inode | 321 | fs/ncpfs/dir.c | c_ino = inode->i_ino; |
inode | 355 | fs/ncpfs/dir.c | ino_info = ncp_find_dir_inode(inode, |
inode | 377 | fs/ncpfs/dir.c | if ( (inode->i_dev != c_dev) |
inode | 378 | fs/ncpfs/dir.c | || (inode->i_ino != c_ino) |
inode | 454 | fs/ncpfs/dir.c | ncp_do_readdir(struct ncp_server *server, struct inode *dir, int fpos, |
inode | 458 | fs/ncpfs/dir.c | static struct inode *last_dir; |
inode | 526 | fs/ncpfs/dir.c | ncp_invalid_dir_cache(struct inode *ino) |
inode | 554 | fs/ncpfs/dir.c | static struct inode * |
inode | 555 | fs/ncpfs/dir.c | ncp_iget(struct inode *dir, struct nw_file_info *finfo) |
inode | 557 | fs/ncpfs/dir.c | struct inode *inode; |
inode | 601 | fs/ncpfs/dir.c | if (!(inode = iget(dir->i_sb, ncp_info_ino(NCP_SERVER(dir), |
inode | 608 | fs/ncpfs/dir.c | return inode; |
inode | 717 | fs/ncpfs/dir.c | ncp_find_dir_inode(struct inode *dir, const char *name) |
inode | 751 | fs/ncpfs/dir.c | ncp_lookup(struct inode *dir, const char *__name, int len, |
inode | 752 | fs/ncpfs/dir.c | struct inode **result) |
inode | 903 | fs/ncpfs/dir.c | ncp_create(struct inode *dir, const char *name, int len, int mode, |
inode | 904 | fs/ncpfs/dir.c | struct inode **result) |
inode | 955 | fs/ncpfs/dir.c | ncp_mkdir(struct inode *dir, const char *name, int len, int mode) |
inode | 1003 | fs/ncpfs/dir.c | ncp_rmdir(struct inode *dir, const char *name, int len) |
inode | 1047 | fs/ncpfs/dir.c | ncp_unlink(struct inode *dir, const char *name, int len) |
inode | 1090 | fs/ncpfs/dir.c | ncp_rename(struct inode *old_dir, const char *old_name, int old_len, |
inode | 1091 | fs/ncpfs/dir.c | struct inode *new_dir, const char *new_name, int new_len) |
inode | 27 | fs/ncpfs/file.c | ncp_fsync(struct inode *inode, struct file *file) |
inode | 33 | fs/ncpfs/file.c | ncp_make_open(struct inode *i, int right) |
inode | 83 | fs/ncpfs/file.c | ncp_file_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 89 | fs/ncpfs/file.c | DPRINTK("ncp_file_read: enter %s\n", NCP_ISTRUCT(inode)->entryName); |
inode | 91 | fs/ncpfs/file.c | if (inode == NULL) |
inode | 96 | fs/ncpfs/file.c | if (!ncp_conn_valid(NCP_SERVER(inode))) |
inode | 101 | fs/ncpfs/file.c | if (!S_ISREG(inode->i_mode)) |
inode | 104 | fs/ncpfs/file.c | inode->i_mode); |
inode | 110 | fs/ncpfs/file.c | if (pos + count > inode->i_size) |
inode | 112 | fs/ncpfs/file.c | count = inode->i_size - pos; |
inode | 120 | fs/ncpfs/file.c | if ((errno = ncp_make_open(inode, O_RDONLY)) != 0) |
inode | 125 | fs/ncpfs/file.c | bufsize = NCP_SERVER(inode)->buffer_size; |
inode | 136 | fs/ncpfs/file.c | if (ncp_read(NCP_SERVER(inode), NCP_FINFO(inode)->file_handle, |
inode | 154 | fs/ncpfs/file.c | if (!IS_RDONLY(inode)) |
inode | 156 | fs/ncpfs/file.c | inode->i_atime = CURRENT_TIME; |
inode | 159 | fs/ncpfs/file.c | inode->i_dirt = 1; |
inode | 161 | fs/ncpfs/file.c | DPRINTK("ncp_file_read: exit %s\n", NCP_ISTRUCT(inode)->entryName); |
inode | 167 | fs/ncpfs/file.c | ncp_file_write(struct inode *inode, struct file *file, const char *buf, |
inode | 174 | fs/ncpfs/file.c | if (inode == NULL) |
inode | 179 | fs/ncpfs/file.c | if (!ncp_conn_valid(NCP_SERVER(inode))) |
inode | 184 | fs/ncpfs/file.c | if (!S_ISREG(inode->i_mode)) |
inode | 187 | fs/ncpfs/file.c | inode->i_mode); |
inode | 191 | fs/ncpfs/file.c | DPRINTK("ncp_file_write: enter %s\n", NCP_ISTRUCT(inode)->entryName); |
inode | 198 | fs/ncpfs/file.c | if ((errno = ncp_make_open(inode, O_RDWR)) != 0) |
inode | 207 | fs/ncpfs/file.c | pos = inode->i_size; |
inode | 210 | fs/ncpfs/file.c | bufsize = NCP_SERVER(inode)->buffer_size; |
inode | 220 | fs/ncpfs/file.c | if (ncp_write(NCP_SERVER(inode), NCP_FINFO(inode)->file_handle, |
inode | 236 | fs/ncpfs/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 237 | fs/ncpfs/file.c | inode->i_dirt = 1; |
inode | 241 | fs/ncpfs/file.c | if (pos > inode->i_size) |
inode | 243 | fs/ncpfs/file.c | inode->i_size = pos; |
inode | 244 | fs/ncpfs/file.c | ncp_invalid_dir_cache(NCP_INOP(inode)->dir->inode); |
inode | 247 | fs/ncpfs/file.c | DPRINTK("ncp_file_write: exit %s\n", NCP_ISTRUCT(inode)->entryName); |
inode | 31 | fs/ncpfs/inode.c | static void ncp_put_inode(struct inode *); |
inode | 32 | fs/ncpfs/inode.c | static void ncp_read_inode(struct inode *); |
inode | 35 | fs/ncpfs/inode.c | static int ncp_notify_change(struct inode *inode, struct iattr *attr); |
inode | 53 | fs/ncpfs/inode.c | ncp_read_inode(struct inode *inode) |
inode | 61 | fs/ncpfs/inode.c | struct ncp_inode_info *inode_info = ncp_find_inode(inode); |
inode | 73 | fs/ncpfs/inode.c | NCP_INOP(inode) = inode_info; |
inode | 74 | fs/ncpfs/inode.c | inode_info->inode = inode; |
inode | 76 | fs/ncpfs/inode.c | if (NCP_ISTRUCT(inode)->attributes & aDIR) |
inode | 78 | fs/ncpfs/inode.c | inode->i_mode = NCP_SERVER(inode)->m.dir_mode; |
inode | 81 | fs/ncpfs/inode.c | inode->i_size = 512; |
inode | 85 | fs/ncpfs/inode.c | inode->i_mode = NCP_SERVER(inode)->m.file_mode; |
inode | 86 | fs/ncpfs/inode.c | inode->i_size = NCP_ISTRUCT(inode)->dataStreamSize; |
inode | 89 | fs/ncpfs/inode.c | DDPRINTK("ncp_read_inode: inode->i_mode = %u\n", inode->i_mode); |
inode | 91 | fs/ncpfs/inode.c | inode->i_nlink = 1; |
inode | 92 | fs/ncpfs/inode.c | inode->i_uid = NCP_SERVER(inode)->m.uid; |
inode | 93 | fs/ncpfs/inode.c | inode->i_gid = NCP_SERVER(inode)->m.gid; |
inode | 94 | fs/ncpfs/inode.c | inode->i_blksize = 512; |
inode | 95 | fs/ncpfs/inode.c | inode->i_rdev = 0; |
inode | 97 | fs/ncpfs/inode.c | if ((inode->i_blksize != 0) && (inode->i_size != 0)) |
inode | 99 | fs/ncpfs/inode.c | inode->i_blocks = |
inode | 100 | fs/ncpfs/inode.c | (inode->i_size - 1) / inode->i_blksize + 1; |
inode | 104 | fs/ncpfs/inode.c | inode->i_blocks = 0; |
inode | 107 | fs/ncpfs/inode.c | inode->i_mtime = ncp_date_dos2unix(NCP_ISTRUCT(inode)->modifyTime, |
inode | 108 | fs/ncpfs/inode.c | NCP_ISTRUCT(inode)->modifyDate); |
inode | 109 | fs/ncpfs/inode.c | inode->i_ctime = ncp_date_dos2unix(NCP_ISTRUCT(inode)->creationTime, |
inode | 110 | fs/ncpfs/inode.c | NCP_ISTRUCT(inode)->creationDate); |
inode | 111 | fs/ncpfs/inode.c | inode->i_atime = ncp_date_dos2unix(0, |
inode | 112 | fs/ncpfs/inode.c | NCP_ISTRUCT(inode)->lastAccessDate); |
inode | 114 | fs/ncpfs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 116 | fs/ncpfs/inode.c | inode->i_op = &ncp_file_inode_operations; |
inode | 118 | fs/ncpfs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 120 | fs/ncpfs/inode.c | inode->i_op = &ncp_dir_inode_operations; |
inode | 124 | fs/ncpfs/inode.c | inode->i_op = NULL; |
inode | 129 | fs/ncpfs/inode.c | ncp_put_inode(struct inode *inode) |
inode | 131 | fs/ncpfs/inode.c | struct nw_file_info *finfo = NCP_FINFO(inode); |
inode | 135 | fs/ncpfs/inode.c | if (ncp_close_file(NCP_SERVER(inode), finfo->file_handle)!=0) |
inode | 145 | fs/ncpfs/inode.c | ncp_free_inode_info(NCP_INOP(inode)); |
inode | 147 | fs/ncpfs/inode.c | if (S_ISDIR(inode->i_mode)) |
inode | 150 | fs/ncpfs/inode.c | inode->i_ino); |
inode | 151 | fs/ncpfs/inode.c | ncp_invalid_dir_cache(inode); |
inode | 154 | fs/ncpfs/inode.c | clear_inode(inode); |
inode | 419 | fs/ncpfs/inode.c | ncp_notify_change(struct inode *inode, struct iattr *attr) |
inode | 425 | fs/ncpfs/inode.c | if (!ncp_conn_valid(NCP_SERVER(inode))) |
inode | 430 | fs/ncpfs/inode.c | if ((result = inode_change_ok(inode, attr)) < 0) |
inode | 434 | fs/ncpfs/inode.c | (attr->ia_uid != NCP_SERVER(inode)->m.uid))) |
inode | 438 | fs/ncpfs/inode.c | (attr->ia_uid != NCP_SERVER(inode)->m.gid))) |
inode | 474 | fs/ncpfs/inode.c | ncp_modify_file_or_subdir_dos_info(NCP_SERVER(inode), |
inode | 475 | fs/ncpfs/inode.c | NCP_ISTRUCT(inode), |
inode | 498 | fs/ncpfs/inode.c | NCP_ISTRUCT(inode)->entryName, attr->ia_size); |
inode | 500 | fs/ncpfs/inode.c | if ((result = ncp_make_open(inode, O_RDWR)) < 0) |
inode | 505 | fs/ncpfs/inode.c | ncp_write(NCP_SERVER(inode), NCP_FINFO(inode)->file_handle, |
inode | 510 | fs/ncpfs/inode.c | ncp_close_file(NCP_SERVER(inode), |
inode | 511 | fs/ncpfs/inode.c | NCP_FINFO(inode)->file_handle); |
inode | 512 | fs/ncpfs/inode.c | NCP_FINFO(inode)->opened = 0; |
inode | 517 | fs/ncpfs/inode.c | ncp_invalid_dir_cache(NCP_INOP(inode)->dir->inode); |
inode | 18 | fs/ncpfs/ioctl.c | ncp_ioctl (struct inode * inode, struct file * filp, |
inode | 24 | fs/ncpfs/ioctl.c | struct ncp_server *server = NCP_SERVER(inode); |
inode | 49 | fs/ncpfs/ioctl.c | if ( (permission(inode, MAY_WRITE) != 0) |
inode | 98 | fs/ncpfs/ioctl.c | if ( (permission(inode, MAY_WRITE) != 0) |
inode | 108 | fs/ncpfs/ioctl.c | if ( (permission(inode, MAY_WRITE) != 0) |
inode | 133 | fs/ncpfs/ioctl.c | info.volume_number = NCP_ISTRUCT(inode)->volNumber; |
inode | 134 | fs/ncpfs/ioctl.c | info.directory_id = NCP_ISTRUCT(inode)->DosDirNum; |
inode | 141 | fs/ncpfs/ioctl.c | if ( (permission(inode, MAY_READ) != 0) |
inode | 36 | fs/ncpfs/mmap.c | struct inode * inode = area->vm_inode; |
inode | 57 | fs/ncpfs/mmap.c | bufsize = NCP_SERVER(inode)->buffer_size; |
inode | 62 | fs/ncpfs/mmap.c | if (ncp_make_open(inode, O_RDONLY) < 0) |
inode | 87 | fs/ncpfs/mmap.c | if (ncp_read(NCP_SERVER(inode), |
inode | 88 | fs/ncpfs/mmap.c | NCP_FINFO(inode)->file_handle, |
inode | 132 | fs/ncpfs/mmap.c | ncp_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 136 | fs/ncpfs/mmap.c | if (!ncp_conn_valid(NCP_SERVER(inode))) |
inode | 144 | fs/ncpfs/mmap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 146 | fs/ncpfs/mmap.c | if (!IS_RDONLY(inode)) { |
inode | 147 | fs/ncpfs/mmap.c | inode->i_atime = CURRENT_TIME; |
inode | 148 | fs/ncpfs/mmap.c | inode->i_dirt = 1; |
inode | 151 | fs/ncpfs/mmap.c | vma->vm_inode = inode; |
inode | 152 | fs/ncpfs/mmap.c | inode->i_count++; |
inode | 125 | fs/ncpfs/sock.c | struct inode *inode; |
inode | 131 | fs/ncpfs/sock.c | || ((inode = file->f_inode) == NULL) |
inode | 132 | fs/ncpfs/sock.c | || (!S_ISSOCK(inode->i_mode))) |
inode | 139 | fs/ncpfs/sock.c | sock = &(inode->u.socket_i); |
inode | 177 | fs/ncpfs/sock.c | struct inode *inode; |
inode | 183 | fs/ncpfs/sock.c | || ((inode = file->f_inode) == NULL) |
inode | 184 | fs/ncpfs/sock.c | || (!S_ISSOCK(inode->i_mode))) |
inode | 191 | fs/ncpfs/sock.c | sock = &(inode->u.socket_i); |
inode | 270 | fs/ncpfs/sock.c | struct inode *inode; |
inode | 276 | fs/ncpfs/sock.c | || ((inode = file->f_inode) == NULL) |
inode | 277 | fs/ncpfs/sock.c | || (!S_ISSOCK(inode->i_mode))) |
inode | 283 | fs/ncpfs/sock.c | sock = &(inode->u.socket_i); |
inode | 321 | fs/ncpfs/sock.c | struct inode *inode; |
inode | 328 | fs/ncpfs/sock.c | int (*select) (struct inode *, struct file *, int, select_table *); |
inode | 347 | fs/ncpfs/sock.c | inode = file->f_inode; |
inode | 349 | fs/ncpfs/sock.c | sock = &inode->u.socket_i; |
inode | 405 | fs/ncpfs/sock.c | if ( !select(inode, file, SEL_IN, &wait_table) |
inode | 406 | fs/ncpfs/sock.c | && !select(inode, file, SEL_IN, NULL)) |
inode | 43 | fs/nfs/bio.c | do_read_nfs_sync(struct inode * inode, struct page * page) |
inode | 48 | fs/nfs/bio.c | int rsize = NFS_SERVER(inode)->rsize; |
inode | 60 | fs/nfs/bio.c | result = nfs_proc_read(NFS_SERVER(inode), NFS_FH(inode), |
inode | 63 | fs/nfs/bio.c | NFS_SERVER(inode)->hostname, |
inode | 64 | fs/nfs/bio.c | inode->i_dev, inode->i_ino, |
inode | 86 | fs/nfs/bio.c | nfs_refresh_inode(inode, &fattr); |
inode | 120 | fs/nfs/bio.c | do_read_nfs_async(struct inode *inode, struct page *page) |
inode | 130 | fs/nfs/bio.c | if (!(req = nfsiod_reserve(NFS_SERVER(inode), nfs_read_cb))) |
inode | 133 | fs/nfs/bio.c | NFS_SERVER(inode), NFS_FH(inode), |
inode | 155 | fs/nfs/bio.c | nfs_readpage(struct inode *inode, struct page *page) |
inode | 163 | fs/nfs/bio.c | if (!PageError(page) && NFS_SERVER(inode)->rsize >= PAGE_SIZE) |
inode | 164 | fs/nfs/bio.c | error = do_read_nfs_async(inode, page); |
inode | 166 | fs/nfs/bio.c | error = do_read_nfs_sync(inode, page); |
inode | 23 | fs/nfs/dir.c | static int nfs_dir_open(struct inode * inode, struct file * file); |
inode | 24 | fs/nfs/dir.c | static int nfs_dir_read(struct inode *, struct file *, char *, int); |
inode | 25 | fs/nfs/dir.c | static int nfs_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 26 | fs/nfs/dir.c | static int nfs_lookup(struct inode *, const char *, int, struct inode **); |
inode | 27 | fs/nfs/dir.c | static int nfs_create(struct inode *, const char *, int, int, struct inode **); |
inode | 28 | fs/nfs/dir.c | static int nfs_mkdir(struct inode *, const char *, int, int); |
inode | 29 | fs/nfs/dir.c | static int nfs_rmdir(struct inode *, const char *, int); |
inode | 30 | fs/nfs/dir.c | static int nfs_unlink(struct inode *, const char *, int); |
inode | 31 | fs/nfs/dir.c | static int nfs_symlink(struct inode *, const char *, int, const char *); |
inode | 32 | fs/nfs/dir.c | static int nfs_link(struct inode *, struct inode *, const char *, int); |
inode | 33 | fs/nfs/dir.c | static int nfs_mknod(struct inode *, const char *, int, int, int); |
inode | 34 | fs/nfs/dir.c | static int nfs_rename(struct inode *, const char *, int, |
inode | 35 | fs/nfs/dir.c | struct inode *, const char *, int); |
inode | 70 | fs/nfs/dir.c | static inline void revalidate_dir(struct nfs_server * server, struct inode * dir) |
inode | 87 | fs/nfs/dir.c | static int nfs_dir_open(struct inode * dir, struct file * file) |
inode | 93 | fs/nfs/dir.c | static int nfs_dir_read(struct inode *inode, struct file *filp, char *buf, |
inode | 109 | fs/nfs/dir.c | static int nfs_readdir(struct inode *inode, struct file *filp, |
inode | 120 | fs/nfs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) { |
inode | 125 | fs/nfs/dir.c | revalidate_dir(NFS_SERVER(inode), inode); |
inode | 153 | fs/nfs/dir.c | if (inode->i_dev == c_dev && inode->i_ino == c_ino) { |
inode | 170 | fs/nfs/dir.c | result = nfs_proc_readdir(NFS_SERVER(inode), NFS_FH(inode), |
inode | 177 | fs/nfs/dir.c | c_dev = inode->i_dev; |
inode | 178 | fs/nfs/dir.c | c_ino = inode->i_ino; |
inode | 193 | fs/nfs/dir.c | if (inode->i_dev != c_dev) |
inode | 195 | fs/nfs/dir.c | if (inode->i_ino != c_ino) |
inode | 238 | fs/nfs/dir.c | int inode; |
inode | 245 | fs/nfs/dir.c | static struct nfs_lookup_cache_entry *nfs_lookup_cache_index(struct inode *dir, |
inode | 254 | fs/nfs/dir.c | && entry->inode == dir->i_ino |
inode | 261 | fs/nfs/dir.c | static int nfs_lookup_cache_lookup(struct inode *dir, const char *filename, |
inode | 285 | fs/nfs/dir.c | static void nfs_lookup_cache_add(struct inode *dir, const char *filename, |
inode | 302 | fs/nfs/dir.c | entry->inode = dir->i_ino; |
inode | 310 | fs/nfs/dir.c | static void nfs_lookup_cache_remove(struct inode *dir, struct inode *inode, |
inode | 318 | fs/nfs/dir.c | if (inode) { |
inode | 319 | fs/nfs/dir.c | dev = inode->i_dev; |
inode | 320 | fs/nfs/dir.c | fileid = inode->i_ino; |
inode | 335 | fs/nfs/dir.c | static void nfs_lookup_cache_refresh(struct inode *file, |
inode | 350 | fs/nfs/dir.c | static int nfs_lookup(struct inode *dir, const char *__name, int len, |
inode | 351 | fs/nfs/dir.c | struct inode **result) |
inode | 391 | fs/nfs/dir.c | static int nfs_create(struct inode *dir, const char *name, int len, int mode, |
inode | 392 | fs/nfs/dir.c | struct inode **result) |
inode | 426 | fs/nfs/dir.c | static int nfs_mknod(struct inode *dir, const char *name, int len, |
inode | 458 | fs/nfs/dir.c | static int nfs_mkdir(struct inode *dir, const char *name, int len, int mode) |
inode | 485 | fs/nfs/dir.c | static int nfs_rmdir(struct inode *dir, const char *name, int len) |
inode | 505 | fs/nfs/dir.c | static int nfs_sillyrename(struct inode *dir, const char *name, int len) |
inode | 507 | fs/nfs/dir.c | struct inode *inode; |
inode | 512 | fs/nfs/dir.c | if (nfs_lookup(dir, name, len, &inode) < 0) |
inode | 514 | fs/nfs/dir.c | if (inode->i_count == 1 || NFS_RENAMED_DIR(inode)) { |
inode | 515 | fs/nfs/dir.c | iput(inode); |
inode | 518 | fs/nfs/dir.c | slen = sprintf(silly, ".nfs%ld", inode->i_ino); |
inode | 521 | fs/nfs/dir.c | iput(inode); |
inode | 529 | fs/nfs/dir.c | NFS_RENAMED_DIR(inode) = dir; |
inode | 532 | fs/nfs/dir.c | iput(inode); |
inode | 536 | fs/nfs/dir.c | void nfs_sillyrename_cleanup(struct inode *inode) |
inode | 538 | fs/nfs/dir.c | struct inode *dir = NFS_RENAMED_DIR(inode); |
inode | 542 | fs/nfs/dir.c | slen = sprintf(silly, ".nfs%ld", inode->i_ino); |
inode | 547 | fs/nfs/dir.c | NFS_RENAMED_DIR(inode) = NULL; |
inode | 550 | fs/nfs/dir.c | static int nfs_unlink(struct inode *dir, const char *name, int len) |
inode | 572 | fs/nfs/dir.c | static int nfs_symlink(struct inode *dir, const char *name, int len, |
inode | 600 | fs/nfs/dir.c | static int nfs_link(struct inode *oldinode, struct inode *dir, |
inode | 631 | fs/nfs/dir.c | static int nfs_rename(struct inode *old_dir, const char *old_name, int old_len, |
inode | 632 | fs/nfs/dir.c | struct inode *new_dir, const char *new_name, int new_len) |
inode | 671 | fs/nfs/dir.c | void nfs_refresh_inode(struct inode *inode, struct nfs_fattr *fattr) |
inode | 675 | fs/nfs/dir.c | if (!inode || !fattr) { |
inode | 679 | fs/nfs/dir.c | if (inode->i_ino != fattr->fileid) { |
inode | 683 | fs/nfs/dir.c | was_empty = (inode->i_mode == 0); |
inode | 684 | fs/nfs/dir.c | inode->i_mode = fattr->mode; |
inode | 685 | fs/nfs/dir.c | inode->i_nlink = fattr->nlink; |
inode | 686 | fs/nfs/dir.c | inode->i_uid = fattr->uid; |
inode | 687 | fs/nfs/dir.c | inode->i_gid = fattr->gid; |
inode | 690 | fs/nfs/dir.c | if (inode->i_size != fattr->size) |
inode | 691 | fs/nfs/dir.c | NFS_CACHEINV(inode); |
inode | 692 | fs/nfs/dir.c | inode->i_size = fattr->size; |
inode | 693 | fs/nfs/dir.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 694 | fs/nfs/dir.c | inode->i_rdev = to_kdev_t(fattr->rdev); |
inode | 696 | fs/nfs/dir.c | inode->i_rdev = 0; |
inode | 697 | fs/nfs/dir.c | inode->i_blocks = fattr->blocks; |
inode | 698 | fs/nfs/dir.c | inode->i_atime = fattr->atime.seconds; |
inode | 699 | fs/nfs/dir.c | inode->i_mtime = fattr->mtime.seconds; |
inode | 700 | fs/nfs/dir.c | inode->i_ctime = fattr->ctime.seconds; |
inode | 701 | fs/nfs/dir.c | if (S_ISREG(inode->i_mode)) |
inode | 702 | fs/nfs/dir.c | inode->i_op = &nfs_file_inode_operations; |
inode | 703 | fs/nfs/dir.c | else if (S_ISDIR(inode->i_mode)) |
inode | 704 | fs/nfs/dir.c | inode->i_op = &nfs_dir_inode_operations; |
inode | 705 | fs/nfs/dir.c | else if (S_ISLNK(inode->i_mode)) |
inode | 706 | fs/nfs/dir.c | inode->i_op = &nfs_symlink_inode_operations; |
inode | 707 | fs/nfs/dir.c | else if (S_ISCHR(inode->i_mode)) |
inode | 708 | fs/nfs/dir.c | inode->i_op = &chrdev_inode_operations; |
inode | 709 | fs/nfs/dir.c | else if (S_ISBLK(inode->i_mode)) |
inode | 710 | fs/nfs/dir.c | inode->i_op = &blkdev_inode_operations; |
inode | 711 | fs/nfs/dir.c | else if (S_ISFIFO(inode->i_mode)) { |
inode | 713 | fs/nfs/dir.c | init_fifo(inode); |
inode | 715 | fs/nfs/dir.c | inode->i_op = NULL; |
inode | 716 | fs/nfs/dir.c | nfs_lookup_cache_refresh(inode, fattr); |
inode | 32 | fs/nfs/file.c | static int nfs_file_mmap(struct inode *, struct file *, struct vm_area_struct *); |
inode | 33 | fs/nfs/file.c | static int nfs_file_read(struct inode *, struct file *, char *, int); |
inode | 34 | fs/nfs/file.c | static int nfs_file_write(struct inode *, struct file *, const char *, int); |
inode | 35 | fs/nfs/file.c | static int nfs_fsync(struct inode *, struct file *); |
inode | 69 | fs/nfs/file.c | static inline void revalidate_inode(struct nfs_server * server, struct inode * inode) |
inode | 73 | fs/nfs/file.c | if (jiffies - NFS_READTIME(inode) < server->acregmax) |
inode | 76 | fs/nfs/file.c | NFS_READTIME(inode) = jiffies; |
inode | 77 | fs/nfs/file.c | if (nfs_proc_getattr(server, NFS_FH(inode), &fattr) == 0) { |
inode | 78 | fs/nfs/file.c | nfs_refresh_inode(inode, &fattr); |
inode | 79 | fs/nfs/file.c | if (fattr.mtime.seconds == NFS_OLDMTIME(inode)) |
inode | 81 | fs/nfs/file.c | NFS_OLDMTIME(inode) = fattr.mtime.seconds; |
inode | 83 | fs/nfs/file.c | invalidate_inode_pages(inode); |
inode | 87 | fs/nfs/file.c | static int nfs_file_read(struct inode * inode, struct file * file, |
inode | 90 | fs/nfs/file.c | revalidate_inode(NFS_SERVER(inode), inode); |
inode | 91 | fs/nfs/file.c | return generic_file_read(inode, file, buf, count); |
inode | 94 | fs/nfs/file.c | static int nfs_file_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 96 | fs/nfs/file.c | revalidate_inode(NFS_SERVER(inode), inode); |
inode | 97 | fs/nfs/file.c | return generic_file_mmap(inode, file, vma); |
inode | 100 | fs/nfs/file.c | static int nfs_fsync(struct inode *inode, struct file *file) |
inode | 105 | fs/nfs/file.c | static int nfs_file_write(struct inode *inode, struct file *file, const char *buf, |
inode | 112 | fs/nfs/file.c | if (!inode) { |
inode | 116 | fs/nfs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 118 | fs/nfs/file.c | inode->i_mode); |
inode | 126 | fs/nfs/file.c | pos = inode->i_size; |
inode | 127 | fs/nfs/file.c | wsize = NFS_SERVER(inode)->wsize; |
inode | 134 | fs/nfs/file.c | result = nfs_proc_write(inode, |
inode | 147 | fs/nfs/file.c | if (pos > inode->i_size) |
inode | 148 | fs/nfs/file.c | inode->i_size = pos; |
inode | 149 | fs/nfs/file.c | nfs_refresh_inode(inode, &fattr); |
inode | 39 | fs/nfs/inode.c | static int nfs_notify_change(struct inode *, struct iattr *); |
inode | 40 | fs/nfs/inode.c | static void nfs_put_inode(struct inode *); |
inode | 42 | fs/nfs/inode.c | static void nfs_read_inode(struct inode *); |
inode | 63 | fs/nfs/inode.c | static void nfs_read_inode(struct inode * inode) |
inode | 65 | fs/nfs/inode.c | int rsize = inode->i_sb->u.nfs_sb.s_server.rsize; |
inode | 66 | fs/nfs/inode.c | int size = inode->i_sb->u.nfs_sb.s_server.wsize; |
inode | 70 | fs/nfs/inode.c | inode->i_blksize = size; |
inode | 71 | fs/nfs/inode.c | inode->i_mode = 0; |
inode | 72 | fs/nfs/inode.c | inode->i_op = NULL; |
inode | 73 | fs/nfs/inode.c | NFS_CACHEINV(inode); |
inode | 76 | fs/nfs/inode.c | static void nfs_put_inode(struct inode * inode) |
inode | 78 | fs/nfs/inode.c | if (NFS_RENAMED_DIR(inode)) |
inode | 79 | fs/nfs/inode.c | nfs_sillyrename_cleanup(inode); |
inode | 80 | fs/nfs/inode.c | if (inode->i_pipe) |
inode | 81 | fs/nfs/inode.c | clear_inode(inode); |
inode | 241 | fs/nfs/inode.c | struct inode *nfs_fhget(struct super_block *sb, struct nfs_fh *fhandle, |
inode | 246 | fs/nfs/inode.c | struct inode *inode; |
inode | 261 | fs/nfs/inode.c | if (!(inode = iget(sb, fattr->fileid))) { |
inode | 265 | fs/nfs/inode.c | if (inode->i_dev == sb->s_dev) { |
inode | 266 | fs/nfs/inode.c | if (inode->i_ino != fattr->fileid) { |
inode | 268 | fs/nfs/inode.c | return inode; |
inode | 270 | fs/nfs/inode.c | *NFS_FH(inode) = *fhandle; |
inode | 271 | fs/nfs/inode.c | nfs_refresh_inode(inode, fattr); |
inode | 273 | fs/nfs/inode.c | return inode; |
inode | 276 | fs/nfs/inode.c | int nfs_notify_change(struct inode *inode, struct iattr *attr) |
inode | 297 | fs/nfs/inode.c | sattr.size = S_ISREG(inode->i_mode) ? attr->ia_size : -1; |
inode | 311 | fs/nfs/inode.c | error = nfs_proc_setattr(NFS_SERVER(inode), NFS_FH(inode), |
inode | 314 | fs/nfs/inode.c | nfs_refresh_inode(inode, &fattr); |
inode | 315 | fs/nfs/inode.c | inode->i_dirt = 0; |
inode | 509 | fs/nfs/nfsroot.c | struct inode *inode; |
inode | 514 | fs/nfs/nfsroot.c | inode = file->f_inode; |
inode | 515 | fs/nfs/nfsroot.c | *sock = &inode->u.socket_i; |
inode | 1425 | fs/nfs/nfsroot.c | static struct inode *nfs_sock_inode; /* Inode containing socket */ |
inode | 493 | fs/nfs/proc.c | int nfs_proc_write(struct inode * inode, int offset, |
inode | 500 | fs/nfs/proc.c | struct nfs_server * server = NFS_SERVER(inode); |
inode | 501 | fs/nfs/proc.c | struct nfs_fh *fhandle = NFS_FH(inode); |
inode | 521 | fs/nfs/proc.c | update_vm_cache(inode, offset, kdata, count); |
inode | 21 | fs/nfs/symlink.c | static int nfs_readlink(struct inode *, char *, int); |
inode | 22 | fs/nfs/symlink.c | static int nfs_follow_link(struct inode *, struct inode *, int, int, |
inode | 23 | fs/nfs/symlink.c | struct inode **); |
inode | 48 | fs/nfs/symlink.c | static int nfs_follow_link(struct inode *dir, struct inode *inode, |
inode | 49 | fs/nfs/symlink.c | int flag, int mode, struct inode **res_inode) |
inode | 60 | fs/nfs/symlink.c | if (!inode) { |
inode | 64 | fs/nfs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 66 | fs/nfs/symlink.c | *res_inode = inode; |
inode | 70 | fs/nfs/symlink.c | iput(inode); |
inode | 74 | fs/nfs/symlink.c | error = nfs_proc_readlink(NFS_SERVER(inode), NFS_FH(inode), &mem, |
inode | 77 | fs/nfs/symlink.c | iput(inode); |
inode | 88 | fs/nfs/symlink.c | iput(inode); |
inode | 96 | fs/nfs/symlink.c | static int nfs_readlink(struct inode *inode, char *buffer, int buflen) |
inode | 102 | fs/nfs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 103 | fs/nfs/symlink.c | iput(inode); |
inode | 108 | fs/nfs/symlink.c | error = nfs_proc_readlink(NFS_SERVER(inode), NFS_FH(inode), &mem, |
inode | 110 | fs/nfs/symlink.c | iput(inode); |
inode | 44 | fs/noquot.c | void dquot_initialize(struct inode *inode, short type) |
inode | 48 | fs/noquot.c | void dquot_drop(struct inode *inode) |
inode | 25 | fs/open.c | struct inode * inode; |
inode | 31 | fs/open.c | error = namei(path,&inode); |
inode | 34 | fs/open.c | if (!inode->i_sb->s_op->statfs) { |
inode | 35 | fs/open.c | iput(inode); |
inode | 38 | fs/open.c | inode->i_sb->s_op->statfs(inode->i_sb, buf, sizeof(struct statfs)); |
inode | 39 | fs/open.c | iput(inode); |
inode | 45 | fs/open.c | struct inode * inode; |
inode | 54 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 56 | fs/open.c | if (!inode->i_sb->s_op->statfs) |
inode | 58 | fs/open.c | inode->i_sb->s_op->statfs(inode->i_sb, buf, sizeof(struct statfs)); |
inode | 62 | fs/open.c | int do_truncate(struct inode *inode, unsigned long length) |
inode | 67 | fs/open.c | down(&inode->i_sem); |
inode | 70 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 73 | fs/open.c | vmtruncate(inode, length); |
inode | 74 | fs/open.c | if (inode->i_op && inode->i_op->truncate) |
inode | 75 | fs/open.c | inode->i_op->truncate(inode); |
inode | 77 | fs/open.c | up(&inode->i_sem); |
inode | 83 | fs/open.c | struct inode * inode; |
inode | 86 | fs/open.c | error = namei(path,&inode); |
inode | 89 | fs/open.c | if (S_ISDIR(inode->i_mode)) { |
inode | 90 | fs/open.c | iput(inode); |
inode | 93 | fs/open.c | if ((error = permission(inode,MAY_WRITE)) != 0) { |
inode | 94 | fs/open.c | iput(inode); |
inode | 97 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 98 | fs/open.c | iput(inode); |
inode | 101 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) { |
inode | 102 | fs/open.c | iput(inode); |
inode | 105 | fs/open.c | error = get_write_access(inode); |
inode | 107 | fs/open.c | iput(inode); |
inode | 110 | fs/open.c | error = locks_verify_area(FLOCK_VERIFY_WRITE, inode, NULL, |
inode | 111 | fs/open.c | length < inode->i_size ? length : inode->i_size, |
inode | 112 | fs/open.c | abs(inode->i_size - length)); |
inode | 115 | fs/open.c | error = do_truncate(inode, length); |
inode | 116 | fs/open.c | put_write_access(inode); |
inode | 117 | fs/open.c | iput(inode); |
inode | 123 | fs/open.c | struct inode * inode; |
inode | 129 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 131 | fs/open.c | if (S_ISDIR(inode->i_mode) || !(file->f_mode & FMODE_WRITE)) |
inode | 133 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) |
inode | 135 | fs/open.c | error = locks_verify_area(FLOCK_VERIFY_WRITE, inode, file, |
inode | 136 | fs/open.c | length < inode->i_size ? length : inode->i_size, |
inode | 137 | fs/open.c | abs(inode->i_size - length)); |
inode | 140 | fs/open.c | return do_truncate(inode, length); |
inode | 159 | fs/open.c | struct inode * inode; |
inode | 162 | fs/open.c | error = namei(filename,&inode); |
inode | 165 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 166 | fs/open.c | iput(inode); |
inode | 174 | fs/open.c | iput(inode); |
inode | 181 | fs/open.c | if ((error = permission(inode,MAY_WRITE)) != 0) { |
inode | 182 | fs/open.c | iput(inode); |
inode | 186 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 187 | fs/open.c | iput(inode); |
inode | 200 | fs/open.c | struct inode * inode; |
inode | 203 | fs/open.c | error = namei(filename,&inode); |
inode | 206 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 207 | fs/open.c | iput(inode); |
inode | 216 | fs/open.c | iput(inode); |
inode | 224 | fs/open.c | if ((error = permission(inode,MAY_WRITE)) != 0) { |
inode | 225 | fs/open.c | iput(inode); |
inode | 229 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 230 | fs/open.c | iput(inode); |
inode | 240 | fs/open.c | struct inode * inode; |
inode | 250 | fs/open.c | res = namei(filename,&inode); |
inode | 252 | fs/open.c | res = permission(inode, mode); |
inode | 253 | fs/open.c | iput(inode); |
inode | 262 | fs/open.c | struct inode * inode; |
inode | 265 | fs/open.c | error = namei(filename,&inode); |
inode | 268 | fs/open.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 269 | fs/open.c | iput(inode); |
inode | 272 | fs/open.c | if ((error = permission(inode,MAY_EXEC)) != 0) { |
inode | 273 | fs/open.c | iput(inode); |
inode | 277 | fs/open.c | current->fs->pwd = inode; |
inode | 283 | fs/open.c | struct inode * inode; |
inode | 289 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 291 | fs/open.c | if (!S_ISDIR(inode->i_mode)) |
inode | 293 | fs/open.c | if ((error = permission(inode,MAY_EXEC)) != 0) |
inode | 296 | fs/open.c | current->fs->pwd = inode; |
inode | 297 | fs/open.c | inode->i_count++; |
inode | 303 | fs/open.c | struct inode * inode; |
inode | 306 | fs/open.c | error = namei(filename,&inode); |
inode | 309 | fs/open.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 310 | fs/open.c | iput(inode); |
inode | 314 | fs/open.c | iput(inode); |
inode | 318 | fs/open.c | current->fs->root = inode; |
inode | 324 | fs/open.c | struct inode * inode; |
inode | 330 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 332 | fs/open.c | if (IS_RDONLY(inode)) |
inode | 334 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) |
inode | 337 | fs/open.c | mode = inode->i_mode; |
inode | 338 | fs/open.c | newattrs.ia_mode = (mode & S_IALLUGO) | (inode->i_mode & ~S_IALLUGO); |
inode | 340 | fs/open.c | inode->i_dirt = 1; |
inode | 341 | fs/open.c | return notify_change(inode, &newattrs); |
inode | 346 | fs/open.c | struct inode * inode; |
inode | 350 | fs/open.c | error = namei(filename,&inode); |
inode | 353 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 354 | fs/open.c | iput(inode); |
inode | 357 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) { |
inode | 358 | fs/open.c | iput(inode); |
inode | 362 | fs/open.c | mode = inode->i_mode; |
inode | 363 | fs/open.c | newattrs.ia_mode = (mode & S_IALLUGO) | (inode->i_mode & ~S_IALLUGO); |
inode | 365 | fs/open.c | inode->i_dirt = 1; |
inode | 366 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 367 | fs/open.c | iput(inode); |
inode | 373 | fs/open.c | struct inode * inode; |
inode | 380 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 382 | fs/open.c | if (IS_RDONLY(inode)) |
inode | 384 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) |
inode | 387 | fs/open.c | user = inode->i_uid; |
inode | 389 | fs/open.c | group = inode->i_gid; |
inode | 390 | fs/open.c | newattrs.ia_mode = inode->i_mode; |
inode | 397 | fs/open.c | if (user != inode->i_uid && (inode->i_mode & S_ISUID)) { |
inode | 407 | fs/open.c | if (group != inode->i_gid && |
inode | 408 | fs/open.c | ((inode->i_mode & (S_ISGID | S_IXGRP)) == (S_ISGID | S_IXGRP))) { |
inode | 412 | fs/open.c | inode->i_dirt = 1; |
inode | 413 | fs/open.c | if (inode->i_sb && inode->i_sb->dq_op) { |
inode | 414 | fs/open.c | inode->i_sb->dq_op->initialize(inode, -1); |
inode | 415 | fs/open.c | if (inode->i_sb->dq_op->transfer(inode, &newattrs, 0)) |
inode | 417 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 419 | fs/open.c | inode->i_sb->dq_op->transfer(inode, &newattrs, 1); |
inode | 421 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 427 | fs/open.c | struct inode * inode; |
inode | 431 | fs/open.c | error = lnamei(filename,&inode); |
inode | 434 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 435 | fs/open.c | iput(inode); |
inode | 438 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) { |
inode | 439 | fs/open.c | iput(inode); |
inode | 443 | fs/open.c | user = inode->i_uid; |
inode | 445 | fs/open.c | group = inode->i_gid; |
inode | 446 | fs/open.c | newattrs.ia_mode = inode->i_mode; |
inode | 453 | fs/open.c | if (user != inode->i_uid && (inode->i_mode & S_ISUID)) { |
inode | 463 | fs/open.c | if (group != inode->i_gid && |
inode | 464 | fs/open.c | ((inode->i_mode & (S_ISGID | S_IXGRP)) == (S_ISGID | S_IXGRP))) { |
inode | 468 | fs/open.c | inode->i_dirt = 1; |
inode | 469 | fs/open.c | if (inode->i_sb->dq_op) { |
inode | 470 | fs/open.c | inode->i_sb->dq_op->initialize(inode, -1); |
inode | 471 | fs/open.c | if (inode->i_sb->dq_op->transfer(inode, &newattrs, 0)) |
inode | 473 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 475 | fs/open.c | inode->i_sb->dq_op->transfer(inode, &newattrs, 1); |
inode | 477 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 478 | fs/open.c | iput(inode); |
inode | 498 | fs/open.c | struct inode * inode; |
inode | 511 | fs/open.c | error = open_namei(filename,flag,mode,&inode,NULL); |
inode | 515 | fs/open.c | error = get_write_access(inode); |
inode | 520 | fs/open.c | f->f_inode = inode; |
inode | 524 | fs/open.c | if (inode->i_op) |
inode | 525 | fs/open.c | f->f_op = inode->i_op->default_file_ops; |
inode | 527 | fs/open.c | error = f->f_op->open(inode,f); |
inode | 547 | fs/open.c | f->f_op->release(inode,f); |
inode | 550 | fs/open.c | put_write_access(inode); |
inode | 552 | fs/open.c | iput(inode); |
inode | 586 | fs/open.c | struct inode *inode; |
inode | 592 | fs/open.c | inode = filp->f_inode; |
inode | 593 | fs/open.c | if (inode) |
inode | 600 | fs/open.c | filp->f_op->release(inode,filp); |
inode | 604 | fs/open.c | put_write_access(inode); |
inode | 605 | fs/open.c | iput(inode); |
inode | 30 | fs/pipe.c | static int pipe_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 36 | fs/pipe.c | if (PIPE_LOCK(*inode)) |
inode | 38 | fs/pipe.c | if (PIPE_EMPTY(*inode)) |
inode | 39 | fs/pipe.c | if (PIPE_WRITERS(*inode)) |
inode | 43 | fs/pipe.c | } else while (PIPE_EMPTY(*inode) || PIPE_LOCK(*inode)) { |
inode | 44 | fs/pipe.c | if (PIPE_EMPTY(*inode)) { |
inode | 45 | fs/pipe.c | if (!PIPE_WRITERS(*inode)) |
inode | 50 | fs/pipe.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 52 | fs/pipe.c | PIPE_LOCK(*inode)++; |
inode | 53 | fs/pipe.c | while (count>0 && (size = PIPE_SIZE(*inode))) { |
inode | 54 | fs/pipe.c | chars = PIPE_MAX_RCHUNK(*inode); |
inode | 60 | fs/pipe.c | pipebuf = PIPE_BASE(*inode)+PIPE_START(*inode); |
inode | 61 | fs/pipe.c | PIPE_START(*inode) += chars; |
inode | 62 | fs/pipe.c | PIPE_START(*inode) &= (PIPE_BUF-1); |
inode | 63 | fs/pipe.c | PIPE_LEN(*inode) -= chars; |
inode | 68 | fs/pipe.c | PIPE_LOCK(*inode)--; |
inode | 69 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 72 | fs/pipe.c | if (PIPE_WRITERS(*inode)) |
inode | 77 | fs/pipe.c | static int pipe_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 82 | fs/pipe.c | if (!PIPE_READERS(*inode)) { /* no readers */ |
inode | 92 | fs/pipe.c | while ((PIPE_FREE(*inode) < free) || PIPE_LOCK(*inode)) { |
inode | 93 | fs/pipe.c | if (!PIPE_READERS(*inode)) { /* no readers */ |
inode | 101 | fs/pipe.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 103 | fs/pipe.c | PIPE_LOCK(*inode)++; |
inode | 104 | fs/pipe.c | while (count>0 && (free = PIPE_FREE(*inode))) { |
inode | 105 | fs/pipe.c | chars = PIPE_MAX_WCHUNK(*inode); |
inode | 110 | fs/pipe.c | pipebuf = PIPE_BASE(*inode)+PIPE_END(*inode); |
inode | 112 | fs/pipe.c | PIPE_LEN(*inode) += chars; |
inode | 117 | fs/pipe.c | PIPE_LOCK(*inode)--; |
inode | 118 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 124 | fs/pipe.c | static int pipe_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 129 | fs/pipe.c | static int bad_pipe_r(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 134 | fs/pipe.c | static int bad_pipe_w(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 139 | fs/pipe.c | static int pipe_ioctl(struct inode *pino, struct file * filp, |
inode | 155 | fs/pipe.c | static int pipe_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 159 | fs/pipe.c | if (!PIPE_EMPTY(*inode) || !PIPE_WRITERS(*inode)) |
inode | 161 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 164 | fs/pipe.c | if (!PIPE_FULL(*inode) || !PIPE_READERS(*inode)) |
inode | 166 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 169 | fs/pipe.c | if (!PIPE_READERS(*inode) || !PIPE_WRITERS(*inode)) |
inode | 171 | fs/pipe.c | select_wait(&inode->i_wait,wait); |
inode | 182 | fs/pipe.c | static int fifo_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 186 | fs/pipe.c | if (!PIPE_EMPTY(*inode)) |
inode | 188 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 191 | fs/pipe.c | if (!PIPE_FULL(*inode) || !PIPE_READERS(*inode)) |
inode | 193 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 196 | fs/pipe.c | if (!PIPE_READERS(*inode) || !PIPE_WRITERS(*inode)) |
inode | 198 | fs/pipe.c | select_wait(&inode->i_wait,wait); |
inode | 214 | fs/pipe.c | static int connect_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 216 | fs/pipe.c | while (!PIPE_SIZE(*inode)) { |
inode | 217 | fs/pipe.c | if (PIPE_WRITERS(*inode)) |
inode | 221 | fs/pipe.c | wake_up_interruptible(& PIPE_WAIT(*inode)); |
inode | 224 | fs/pipe.c | interruptible_sleep_on(& PIPE_WAIT(*inode)); |
inode | 227 | fs/pipe.c | return pipe_read(inode,filp,buf,count); |
inode | 230 | fs/pipe.c | static int connect_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 234 | fs/pipe.c | if (!PIPE_EMPTY(*inode)) { |
inode | 238 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 241 | fs/pipe.c | if (!PIPE_FULL(*inode)) |
inode | 243 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 246 | fs/pipe.c | if (!PIPE_READERS(*inode) || !PIPE_WRITERS(*inode)) |
inode | 248 | fs/pipe.c | select_wait(&inode->i_wait,wait); |
inode | 254 | fs/pipe.c | static void pipe_read_release(struct inode * inode, struct file * filp) |
inode | 256 | fs/pipe.c | PIPE_READERS(*inode)--; |
inode | 257 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 260 | fs/pipe.c | static void pipe_write_release(struct inode * inode, struct file * filp) |
inode | 262 | fs/pipe.c | PIPE_WRITERS(*inode)--; |
inode | 263 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 266 | fs/pipe.c | static void pipe_rdwr_release(struct inode * inode, struct file * filp) |
inode | 269 | fs/pipe.c | PIPE_READERS(*inode)--; |
inode | 271 | fs/pipe.c | PIPE_WRITERS(*inode)--; |
inode | 272 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 275 | fs/pipe.c | static int pipe_read_open(struct inode * inode, struct file * filp) |
inode | 277 | fs/pipe.c | PIPE_READERS(*inode)++; |
inode | 281 | fs/pipe.c | static int pipe_write_open(struct inode * inode, struct file * filp) |
inode | 283 | fs/pipe.c | PIPE_WRITERS(*inode)++; |
inode | 287 | fs/pipe.c | static int pipe_rdwr_open(struct inode * inode, struct file * filp) |
inode | 290 | fs/pipe.c | PIPE_READERS(*inode)++; |
inode | 292 | fs/pipe.c | PIPE_WRITERS(*inode)++; |
inode | 413 | fs/pipe.c | struct inode * inode; |
inode | 417 | fs/pipe.c | inode = get_pipe_inode(); |
inode | 418 | fs/pipe.c | if (!inode) |
inode | 425 | fs/pipe.c | iput(inode); |
inode | 426 | fs/pipe.c | iput(inode); |
inode | 438 | fs/pipe.c | iput(inode); |
inode | 439 | fs/pipe.c | iput(inode); |
inode | 446 | fs/pipe.c | f[0]->f_inode = f[1]->f_inode = inode; |
inode | 59 | fs/proc/array.c | static int read_core(struct inode * inode, struct file * file,char * buf, int count) |
inode | 129 | fs/proc/array.c | static int read_profile(struct inode *inode, struct file *file, char *buf, int count) |
inode | 156 | fs/proc/array.c | static int write_profile(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 1075 | fs/proc/array.c | static int array_read(struct inode * inode, struct file * file,char * buf, int count) |
inode | 1090 | fs/proc/array.c | type = inode->i_ino; |
inode | 1094 | fs/proc/array.c | dp = (struct proc_dir_entry *) inode->u.generic_ip; |
inode | 1159 | fs/proc/array.c | static int arraylong_read (struct inode * inode, struct file * file, char * buf, int count) |
inode | 1161 | fs/proc/array.c | unsigned int pid = inode->i_ino >> 16; |
inode | 1162 | fs/proc/array.c | unsigned int type = inode->i_ino & 0x0000ffff; |
inode | 52 | fs/proc/base.c | static void proc_pid_fill_inode(struct inode * inode) |
inode | 55 | fs/proc/base.c | int pid = inode->i_ino >> 16; |
inode | 56 | fs/proc/base.c | int ino = inode->i_ino & 0xffff; |
inode | 61 | fs/proc/base.c | inode->i_uid = p->euid; |
inode | 62 | fs/proc/base.c | inode->i_gid = p->gid; |
inode | 16 | fs/proc/fd.c | static int proc_readfd(struct inode *, struct file *, void *, filldir_t); |
inode | 17 | fs/proc/fd.c | static int proc_lookupfd(struct inode *,const char *,int,struct inode **); |
inode | 55 | fs/proc/fd.c | static int proc_lookupfd(struct inode * dir, const char * name, int len, |
inode | 56 | fs/proc/fd.c | struct inode ** result) |
inode | 121 | fs/proc/fd.c | static int proc_readfd(struct inode * inode, struct file * filp, |
inode | 130 | fs/proc/fd.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 132 | fs/proc/fd.c | ino = inode->i_ino; |
inode | 139 | fs/proc/fd.c | unsigned long ino = inode->i_ino; |
inode | 19 | fs/proc/inode.c | static void proc_put_inode(struct inode *inode) |
inode | 21 | fs/proc/inode.c | if (inode->i_nlink) |
inode | 23 | fs/proc/inode.c | inode->i_size = 0; |
inode | 74 | fs/proc/inode.c | struct inode * proc_get_inode(struct super_block * s, int ino, struct proc_dir_entry * de) |
inode | 76 | fs/proc/inode.c | struct inode * inode = iget(s, ino); |
inode | 77 | fs/proc/inode.c | if (inode && inode->i_sb == s) { |
inode | 78 | fs/proc/inode.c | inode->u.generic_ip = (void *) de; |
inode | 81 | fs/proc/inode.c | inode->i_mode = de->mode; |
inode | 82 | fs/proc/inode.c | inode->i_uid = de->uid; |
inode | 83 | fs/proc/inode.c | inode->i_gid = de->gid; |
inode | 86 | fs/proc/inode.c | inode->i_size = de->size; |
inode | 88 | fs/proc/inode.c | inode->i_op = de->ops; |
inode | 90 | fs/proc/inode.c | inode->i_nlink = de->nlink; |
inode | 92 | fs/proc/inode.c | de->fill_inode(inode); |
inode | 95 | fs/proc/inode.c | return inode; |
inode | 132 | fs/proc/inode.c | void proc_read_inode(struct inode * inode) |
inode | 138 | fs/proc/inode.c | inode->i_op = NULL; |
inode | 139 | fs/proc/inode.c | inode->i_mode = 0; |
inode | 140 | fs/proc/inode.c | inode->i_uid = 0; |
inode | 141 | fs/proc/inode.c | inode->i_gid = 0; |
inode | 142 | fs/proc/inode.c | inode->i_nlink = 1; |
inode | 143 | fs/proc/inode.c | inode->i_size = 0; |
inode | 144 | fs/proc/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 145 | fs/proc/inode.c | inode->i_blocks = 0; |
inode | 146 | fs/proc/inode.c | inode->i_blksize = 1024; |
inode | 147 | fs/proc/inode.c | ino = inode->i_ino; |
inode | 156 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO; |
inode | 157 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 160 | fs/proc/inode.c | inode->i_nlink++; |
inode | 167 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR; |
inode | 168 | fs/proc/inode.c | inode->i_op = &proc_kmsg_inode_operations; |
inode | 171 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 174 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO; |
inode | 175 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 176 | fs/proc/inode.c | inode->i_op = &proc_scsi_inode_operations; |
inode | 179 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR; |
inode | 180 | fs/proc/inode.c | inode->i_op = &proc_kcore_inode_operations; |
inode | 181 | fs/proc/inode.c | inode->i_size = (MAP_NR(high_memory) << PAGE_SHIFT) + PAGE_SIZE; |
inode | 184 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO | S_IWUSR; |
inode | 185 | fs/proc/inode.c | inode->i_op = &proc_profile_inode_operations; |
inode | 186 | fs/proc/inode.c | inode->i_size = (1+prof_len) * sizeof(unsigned long); |
inode | 189 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO; |
inode | 190 | fs/proc/inode.c | inode->i_op = &proc_array_inode_operations; |
inode | 197 | fs/proc/inode.c | inode->i_uid = p->euid; |
inode | 198 | fs/proc/inode.c | inode->i_gid = p->egid; |
inode | 202 | fs/proc/inode.c | inode->i_nlink = 4; |
inode | 205 | fs/proc/inode.c | inode->i_op = &proc_mem_inode_operations; |
inode | 206 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR | S_IWUSR; |
inode | 211 | fs/proc/inode.c | inode->i_op = &proc_link_inode_operations; |
inode | 212 | fs/proc/inode.c | inode->i_size = 64; |
inode | 213 | fs/proc/inode.c | inode->i_mode = S_IFLNK | S_IRWXU; |
inode | 216 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUSR | S_IXUSR; |
inode | 217 | fs/proc/inode.c | inode->i_op = &proc_fd_inode_operations; |
inode | 218 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 221 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR; |
inode | 222 | fs/proc/inode.c | inode->i_op = &proc_array_inode_operations; |
inode | 228 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO; |
inode | 229 | fs/proc/inode.c | inode->i_op = &proc_array_inode_operations; |
inode | 232 | fs/proc/inode.c | inode->i_mode = S_IFIFO | S_IRUGO; |
inode | 233 | fs/proc/inode.c | inode->i_op = &proc_arraylong_inode_operations; |
inode | 241 | fs/proc/inode.c | inode->i_op = &proc_link_inode_operations; |
inode | 242 | fs/proc/inode.c | inode->i_size = 64; |
inode | 243 | fs/proc/inode.c | inode->i_mode = S_IFLNK; |
inode | 245 | fs/proc/inode.c | inode->i_mode |= S_IRUSR | S_IXUSR; |
inode | 247 | fs/proc/inode.c | inode->i_mode |= S_IWUSR | S_IXUSR; |
inode | 253 | fs/proc/inode.c | void proc_write_inode(struct inode * inode) |
inode | 255 | fs/proc/inode.c | inode->i_dirt=0; |
inode | 21 | fs/proc/kmsg.c | static int kmsg_open(struct inode * inode, struct file * file) |
inode | 26 | fs/proc/kmsg.c | static void kmsg_release(struct inode * inode, struct file * file) |
inode | 31 | fs/proc/kmsg.c | static int kmsg_read(struct inode * inode, struct file * file,char * buf, int count) |
inode | 36 | fs/proc/kmsg.c | static int kmsg_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 18 | fs/proc/link.c | static int proc_readlink(struct inode *, char *, int); |
inode | 19 | fs/proc/link.c | static int proc_follow_link(struct inode *, struct inode *, int, int, |
inode | 20 | fs/proc/link.c | struct inode **); |
inode | 65 | fs/proc/link.c | static int proc_follow_link(struct inode * dir, struct inode * inode, |
inode | 66 | fs/proc/link.c | int flag, int mode, struct inode ** res_inode) |
inode | 70 | fs/proc/link.c | struct inode * new_inode; |
inode | 76 | fs/proc/link.c | if (!inode) |
inode | 78 | fs/proc/link.c | if ((error = permission(inode, MAY_EXEC)) != 0){ |
inode | 79 | fs/proc/link.c | iput(inode); |
inode | 82 | fs/proc/link.c | ino = inode->i_ino; |
inode | 89 | fs/proc/link.c | iput(inode); |
inode | 130 | fs/proc/link.c | iput(inode); |
inode | 138 | fs/proc/link.c | static int proc_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 144 | fs/proc/link.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 145 | fs/proc/link.c | iput(inode); |
inode | 148 | fs/proc/link.c | i = proc_follow_link(NULL, inode, 0, 0, &inode); |
inode | 151 | fs/proc/link.c | if (!inode) |
inode | 153 | fs/proc/link.c | dev = kdev_t_to_nr(inode->i_dev); |
inode | 154 | fs/proc/link.c | ino = inode->i_ino; |
inode | 155 | fs/proc/link.c | iput(inode); |
inode | 53 | fs/proc/mem.c | static int mem_read(struct inode * inode, struct file * file,char * buf, int count) |
inode | 66 | fs/proc/mem.c | pid = inode->i_ino; |
inode | 113 | fs/proc/mem.c | static int mem_write(struct inode * inode, struct file * file,char * buf, int count) |
inode | 127 | fs/proc/mem.c | pid = inode->i_ino; |
inode | 176 | fs/proc/mem.c | static int mem_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 193 | fs/proc/mem.c | int mem_mmap(struct inode * inode, struct file * file, |
inode | 208 | fs/proc/mem.c | if (task[i] && task[i]->pid == (inode->i_ino >> 16)) { |
inode | 38 | fs/proc/net.c | static int proc_readnet(struct inode * inode, struct file * file, |
inode | 49 | fs/proc/net.c | dp = (struct proc_dir_entry *) inode->u.generic_ip; |
inode | 23 | fs/proc/root.c | static int proc_root_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 24 | fs/proc/root.c | static int proc_root_lookup(struct inode *,const char *,int,struct inode **); |
inode | 209 | fs/proc/root.c | static int proc_self_followlink(struct inode * dir, struct inode * inode, |
inode | 210 | fs/proc/root.c | int flag, int mode, struct inode ** res_inode) |
inode | 213 | fs/proc/root.c | *res_inode = proc_get_inode(inode->i_sb, (current->pid << 16) + PROC_PID_INO, &proc_pid); |
inode | 214 | fs/proc/root.c | iput(inode); |
inode | 220 | fs/proc/root.c | static int proc_self_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 225 | fs/proc/root.c | iput(inode); |
inode | 386 | fs/proc/root.c | int proc_lookup(struct inode * dir,const char * name, int len, |
inode | 387 | fs/proc/root.c | struct inode ** result) |
inode | 412 | fs/proc/root.c | struct inode * inode; |
inode | 413 | fs/proc/root.c | inode = proc_get_inode(dir->i_sb, de->parent->low_ino, de->parent); |
inode | 415 | fs/proc/root.c | if (!inode) |
inode | 417 | fs/proc/root.c | *result = inode; |
inode | 442 | fs/proc/root.c | static int proc_root_lookup(struct inode * dir,const char * name, int len, |
inode | 443 | fs/proc/root.c | struct inode ** result) |
inode | 495 | fs/proc/root.c | int proc_readdir(struct inode * inode, struct file * filp, |
inode | 502 | fs/proc/root.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 504 | fs/proc/root.c | ino = inode->i_ino; |
inode | 505 | fs/proc/root.c | de = (struct proc_dir_entry *) inode->u.generic_ip; |
inode | 547 | fs/proc/root.c | static int proc_root_readdir(struct inode * inode, struct file * filp, |
inode | 556 | fs/proc/root.c | int error = proc_readdir(inode, filp, dirent, filldir); |
inode | 32 | fs/proc/scsi.c | static int proc_readscsi(struct inode * inode, struct file * file, |
inode | 34 | fs/proc/scsi.c | static int proc_writescsi(struct inode * inode, struct file * file, |
inode | 36 | fs/proc/scsi.c | static int proc_scsilseek(struct inode *, struct file *, off_t, int); |
inode | 104 | fs/proc/scsi.c | static int proc_readscsi(struct inode * inode, struct file * file, |
inode | 127 | fs/proc/scsi.c | length = dispatch_scsi_info_ptr(inode->i_ino, page, &start, |
inode | 163 | fs/proc/scsi.c | static int proc_writescsi(struct inode * inode, struct file * file, |
inode | 177 | fs/proc/scsi.c | ret = dispatch_scsi_info_ptr(inode->i_ino, page, 0, 0, count, 1); |
inode | 186 | fs/proc/scsi.c | static int proc_scsilseek(struct inode * inode, struct file * file, |
inode | 199 | fs/proc/scsi.c | proc_readscsi(inode, file, 0, -1); /* seek in it */ |
inode | 107 | fs/read_write.c | struct inode * inode; |
inode | 109 | fs/read_write.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 117 | fs/read_write.c | error = locks_verify_area(FLOCK_VERIFY_READ,inode,file,file->f_pos,count); |
inode | 123 | fs/read_write.c | return file->f_op->read(inode,file,buf,count); |
inode | 130 | fs/read_write.c | struct inode * inode; |
inode | 133 | fs/read_write.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 141 | fs/read_write.c | error = locks_verify_area(FLOCK_VERIFY_WRITE,inode,file,file->f_pos,count); |
inode | 154 | fs/read_write.c | if (!suser() && (inode->i_mode & (S_ISUID | S_ISGID))) { |
inode | 160 | fs/read_write.c | newattrs.ia_mode = inode->i_mode & |
inode | 161 | fs/read_write.c | ~(S_ISUID | ((inode->i_mode & S_IXGRP) ? S_ISGID : 0)); |
inode | 163 | fs/read_write.c | notify_change(inode, &newattrs); |
inode | 166 | fs/read_write.c | down(&inode->i_sem); |
inode | 167 | fs/read_write.c | written = file->f_op->write(inode,file,buf,count); |
inode | 168 | fs/read_write.c | up(&inode->i_sem); |
inode | 172 | fs/read_write.c | static int sock_readv_writev(int type, struct inode * inode, struct file * file, |
inode | 178 | fs/read_write.c | sock = &inode->u.socket_i; |
inode | 200 | fs/read_write.c | typedef int (*IO_fn_t)(struct inode *, struct file *, char *, int); |
inode | 202 | fs/read_write.c | static int do_readv_writev(int type, struct inode * inode, struct file * file, |
inode | 231 | fs/read_write.c | inode, file, file->f_pos, tot_len); |
inode | 240 | fs/read_write.c | if (inode->i_sock) |
inode | 241 | fs/read_write.c | return sock_readv_writev(type, inode, file, iov, count, tot_len); |
inode | 258 | fs/read_write.c | nr = fn(inode, file, base, len); |
inode | 275 | fs/read_write.c | struct inode * inode; |
inode | 277 | fs/read_write.c | if (fd >= NR_OPEN || !(file = current->files->fd[fd]) || !(inode = file->f_inode)) |
inode | 281 | fs/read_write.c | return do_readv_writev(VERIFY_WRITE, inode, file, vector, count); |
inode | 288 | fs/read_write.c | struct inode * inode; |
inode | 290 | fs/read_write.c | if (fd >= NR_OPEN || !(file = current->files->fd[fd]) || !(inode = file->f_inode)) |
inode | 294 | fs/read_write.c | down(&inode->i_sem); |
inode | 295 | fs/read_write.c | error = do_readv_writev(VERIFY_READ, inode, file, vector, count); |
inode | 296 | fs/read_write.c | up(&inode->i_sem); |
inode | 72 | fs/select.c | struct inode * inode; |
inode | 74 | fs/select.c | int (*select) (struct inode *, struct file *, int, select_table *); |
inode | 76 | fs/select.c | inode = file->f_inode; |
inode | 78 | fs/select.c | return select(inode, file, flag, wait) |
inode | 79 | fs/select.c | || (wait && select(inode, file, flag, NULL)); |
inode | 22 | fs/smbfs/dir.c | smb_dir_read(struct inode *inode, struct file *filp, char *buf, int count); |
inode | 25 | fs/smbfs/dir.c | smb_readdir(struct inode *inode, struct file *filp, |
inode | 29 | fs/smbfs/dir.c | get_pname(struct inode *dir, const char *name, int len, |
inode | 33 | fs/smbfs/dir.c | get_pname_static(struct inode *dir, const char *name, int len, |
inode | 36 | fs/smbfs/dir.c | static struct inode * |
inode | 37 | fs/smbfs/dir.c | smb_iget(struct inode *dir, char *path, struct smb_dirent *finfo); |
inode | 46 | fs/smbfs/dir.c | smb_lookup(struct inode *dir, const char *__name, |
inode | 47 | fs/smbfs/dir.c | int len, struct inode **result); |
inode | 50 | fs/smbfs/dir.c | smb_create(struct inode *dir, const char *name, int len, int mode, |
inode | 51 | fs/smbfs/dir.c | struct inode **result); |
inode | 54 | fs/smbfs/dir.c | smb_mkdir(struct inode *dir, const char *name, int len, int mode); |
inode | 57 | fs/smbfs/dir.c | smb_rmdir(struct inode *dir, const char *name, int len); |
inode | 60 | fs/smbfs/dir.c | smb_unlink(struct inode *dir, const char *name, int len); |
inode | 63 | fs/smbfs/dir.c | smb_rename(struct inode *old_dir, const char *old_name, int old_len, |
inode | 64 | fs/smbfs/dir.c | struct inode *new_dir, const char *new_name, int new_len); |
inode | 121 | fs/smbfs/dir.c | smb_dir_read(struct inode *inode, struct file *filp, char *buf, int count) |
inode | 158 | fs/smbfs/dir.c | smb_readdir(struct inode *inode, struct file *filp, |
inode | 164 | fs/smbfs/dir.c | struct smb_server *server = SMB_SERVER(inode); |
inode | 168 | fs/smbfs/dir.c | inode->i_ino, c_ino); |
inode | 170 | fs/smbfs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) { |
inode | 199 | fs/smbfs/dir.c | smb_invalid_dir_cache(inode->i_ino); |
inode | 202 | fs/smbfs/dir.c | if (inode->i_ino == c_ino) { |
inode | 217 | fs/smbfs/dir.c | result = smb_proc_readdir(server, inode, |
inode | 228 | fs/smbfs/dir.c | c_ino = inode->i_ino; |
inode | 266 | fs/smbfs/dir.c | if ((result = get_pname_static(inode, entry->path, len, |
inode | 288 | fs/smbfs/dir.c | if ( (inode->i_ino != c_ino) |
inode | 343 | fs/smbfs/dir.c | get_pname_static(struct inode *dir, const char *name, int len, |
inode | 432 | fs/smbfs/dir.c | get_pname(struct inode *dir, const char *name, int len, |
inode | 463 | fs/smbfs/dir.c | static struct inode * |
inode | 464 | fs/smbfs/dir.c | smb_iget(struct inode *dir, char *path, struct smb_dirent *finfo) |
inode | 467 | fs/smbfs/dir.c | struct inode *inode; |
inode | 526 | fs/smbfs/dir.c | if (!(inode = iget(dir->i_sb, (int)new_inode_info))) { |
inode | 531 | fs/smbfs/dir.c | return inode; |
inode | 658 | fs/smbfs/dir.c | smb_lookup(struct inode *dir, const char *__name, int len, |
inode | 659 | fs/smbfs/dir.c | struct inode **result) |
inode | 762 | fs/smbfs/dir.c | smb_create(struct inode *dir, const char *name, int len, int mode, |
inode | 763 | fs/smbfs/dir.c | struct inode **result) |
inode | 808 | fs/smbfs/dir.c | smb_mkdir(struct inode *dir, const char *name, int len, int mode) |
inode | 834 | fs/smbfs/dir.c | smb_rmdir(struct inode *dir, const char *name, int len) |
inode | 859 | fs/smbfs/dir.c | smb_unlink(struct inode *dir, const char *name, int len) |
inode | 884 | fs/smbfs/dir.c | smb_rename(struct inode *old_dir, const char *old_name, int old_len, |
inode | 885 | fs/smbfs/dir.c | struct inode *new_dir, const char *new_name, int new_len) |
inode | 26 | fs/smbfs/file.c | smb_fsync(struct inode *inode, struct file *file) |
inode | 32 | fs/smbfs/file.c | smb_make_open(struct inode *i, int right) |
inode | 68 | fs/smbfs/file.c | smb_file_read(struct inode *inode, struct file *file, char *buf, int count) |
inode | 74 | fs/smbfs/file.c | DPRINTK("smb_file_read: enter %s\n", SMB_FINFO(inode)->path); |
inode | 76 | fs/smbfs/file.c | if (!inode) { |
inode | 81 | fs/smbfs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 83 | fs/smbfs/file.c | inode->i_mode); |
inode | 87 | fs/smbfs/file.c | if ((errno = smb_make_open(inode, O_RDONLY)) != 0) |
inode | 92 | fs/smbfs/file.c | if (pos + count > inode->i_size) |
inode | 93 | fs/smbfs/file.c | count = inode->i_size - pos; |
inode | 97 | fs/smbfs/file.c | bufsize = SMB_SERVER(inode)->max_xmit - SMB_HEADER_LEN - 5 * 2 - 5; |
inode | 107 | fs/smbfs/file.c | if ((SMB_SERVER(inode)->blkmode & 1) != 0) { |
inode | 110 | fs/smbfs/file.c | result = smb_proc_read_raw(SMB_SERVER(inode), |
inode | 111 | fs/smbfs/file.c | SMB_FINFO(inode), |
inode | 118 | fs/smbfs/file.c | result = smb_proc_read(SMB_SERVER(inode), |
inode | 119 | fs/smbfs/file.c | SMB_FINFO(inode), |
inode | 136 | fs/smbfs/file.c | if (!IS_RDONLY(inode)) inode->i_atime = CURRENT_TIME; |
inode | 137 | fs/smbfs/file.c | inode->i_dirt = 1; |
inode | 139 | fs/smbfs/file.c | DPRINTK("smb_file_read: exit %s\n", SMB_FINFO(inode)->path); |
inode | 145 | fs/smbfs/file.c | smb_file_write(struct inode *inode, struct file *file, const char *buf, int count) |
inode | 151 | fs/smbfs/file.c | if (!inode) { |
inode | 156 | fs/smbfs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 158 | fs/smbfs/file.c | inode->i_mode); |
inode | 162 | fs/smbfs/file.c | DPRINTK("smb_file_write: enter %s\n", SMB_FINFO(inode)->path); |
inode | 167 | fs/smbfs/file.c | if ((errno = smb_make_open(inode, O_RDWR)) != 0) |
inode | 173 | fs/smbfs/file.c | pos = inode->i_size; |
inode | 175 | fs/smbfs/file.c | bufsize = SMB_SERVER(inode)->max_xmit - SMB_HEADER_LEN - 5 * 2 - 5; |
inode | 180 | fs/smbfs/file.c | SMB_SERVER(inode)->blkmode, |
inode | 181 | fs/smbfs/file.c | SMB_SERVER(inode)->blkmode & 2); |
inode | 188 | fs/smbfs/file.c | if ((SMB_SERVER(inode)->blkmode & 2) != 0) { |
inode | 191 | fs/smbfs/file.c | result = smb_proc_write_raw(SMB_SERVER(inode), |
inode | 192 | fs/smbfs/file.c | SMB_FINFO(inode), |
inode | 199 | fs/smbfs/file.c | result = smb_proc_write(SMB_SERVER(inode), |
inode | 200 | fs/smbfs/file.c | SMB_FINFO(inode), |
inode | 216 | fs/smbfs/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 217 | fs/smbfs/file.c | inode->i_dirt = 1; |
inode | 221 | fs/smbfs/file.c | if (pos > inode->i_size) { |
inode | 222 | fs/smbfs/file.c | inode->i_size = pos; |
inode | 225 | fs/smbfs/file.c | DPRINTK("smb_file_write: exit %s\n", SMB_FINFO(inode)->path); |
inode | 27 | fs/smbfs/inode.c | static void smb_put_inode(struct inode *); |
inode | 28 | fs/smbfs/inode.c | static void smb_read_inode(struct inode *); |
inode | 48 | fs/smbfs/inode.c | smb_read_inode(struct inode *inode) |
inode | 57 | fs/smbfs/inode.c | = (struct smb_inode_info *)(inode->i_ino); |
inode | 60 | fs/smbfs/inode.c | struct smb_inode_info *root = &(SMB_SERVER(inode)->root); |
inode | 87 | fs/smbfs/inode.c | SMB_INOP(inode) = inode_info; |
inode | 89 | fs/smbfs/inode.c | if (SMB_INOP(inode)->finfo.attr & aDIR) |
inode | 90 | fs/smbfs/inode.c | inode->i_mode = SMB_SERVER(inode)->m.dir_mode; |
inode | 92 | fs/smbfs/inode.c | inode->i_mode = SMB_SERVER(inode)->m.file_mode; |
inode | 94 | fs/smbfs/inode.c | DDPRINTK("smb_read_inode: inode->i_mode = %u\n", inode->i_mode); |
inode | 96 | fs/smbfs/inode.c | inode->i_nlink = 1; |
inode | 97 | fs/smbfs/inode.c | inode->i_uid = SMB_SERVER(inode)->m.uid; |
inode | 98 | fs/smbfs/inode.c | inode->i_gid = SMB_SERVER(inode)->m.gid; |
inode | 99 | fs/smbfs/inode.c | inode->i_size = SMB_INOP(inode)->finfo.size; |
inode | 100 | fs/smbfs/inode.c | inode->i_blksize = 1024; |
inode | 101 | fs/smbfs/inode.c | inode->i_rdev = 0; |
inode | 102 | fs/smbfs/inode.c | if ((inode->i_blksize != 0) && (inode->i_size != 0)) |
inode | 103 | fs/smbfs/inode.c | inode->i_blocks = |
inode | 104 | fs/smbfs/inode.c | (inode->i_size - 1) / inode->i_blksize + 1; |
inode | 106 | fs/smbfs/inode.c | inode->i_blocks = 0; |
inode | 108 | fs/smbfs/inode.c | inode->i_mtime = SMB_INOP(inode)->finfo.mtime; |
inode | 109 | fs/smbfs/inode.c | inode->i_ctime = SMB_INOP(inode)->finfo.ctime; |
inode | 110 | fs/smbfs/inode.c | inode->i_atime = SMB_INOP(inode)->finfo.atime; |
inode | 112 | fs/smbfs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 113 | fs/smbfs/inode.c | inode->i_op = &smb_file_inode_operations; |
inode | 114 | fs/smbfs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 115 | fs/smbfs/inode.c | inode->i_op = &smb_dir_inode_operations; |
inode | 117 | fs/smbfs/inode.c | inode->i_op = NULL; |
inode | 122 | fs/smbfs/inode.c | smb_put_inode(struct inode *inode) |
inode | 124 | fs/smbfs/inode.c | struct smb_dirent *finfo = SMB_FINFO(inode); |
inode | 129 | fs/smbfs/inode.c | finfo->mtime = inode->i_mtime; |
inode | 131 | fs/smbfs/inode.c | if (smb_proc_close(SMB_SERVER(inode), finfo)) { |
inode | 137 | fs/smbfs/inode.c | smb_free_inode_info(SMB_INOP(inode)); |
inode | 139 | fs/smbfs/inode.c | if (S_ISDIR(inode->i_mode)) { |
inode | 141 | fs/smbfs/inode.c | inode->i_ino); |
inode | 142 | fs/smbfs/inode.c | smb_invalid_dir_cache(inode->i_ino); |
inode | 145 | fs/smbfs/inode.c | clear_inode(inode); |
inode | 334 | fs/smbfs/inode.c | smb_notify_change(struct inode *inode, struct iattr *attr) |
inode | 338 | fs/smbfs/inode.c | if ((error = inode_change_ok(inode, attr)) < 0) |
inode | 342 | fs/smbfs/inode.c | (attr->ia_uid != SMB_SERVER(inode)->m.uid))) |
inode | 346 | fs/smbfs/inode.c | (attr->ia_uid != SMB_SERVER(inode)->m.gid))) |
inode | 355 | fs/smbfs/inode.c | if ((error = smb_make_open(inode, O_WRONLY)) < 0) |
inode | 358 | fs/smbfs/inode.c | if ((error = smb_proc_trunc(SMB_SERVER(inode), |
inode | 359 | fs/smbfs/inode.c | SMB_FINFO(inode)->fileid, |
inode | 374 | fs/smbfs/inode.c | finfo.ctime = inode->i_ctime; |
inode | 379 | fs/smbfs/inode.c | finfo.mtime = inode->i_mtime; |
inode | 384 | fs/smbfs/inode.c | finfo.atime = inode->i_atime; |
inode | 386 | fs/smbfs/inode.c | if ((error = smb_proc_setattr(SMB_SERVER(inode), |
inode | 387 | fs/smbfs/inode.c | inode, &finfo)) >= 0) { |
inode | 388 | fs/smbfs/inode.c | inode->i_ctime = finfo.ctime; |
inode | 389 | fs/smbfs/inode.c | inode->i_mtime = finfo.mtime; |
inode | 390 | fs/smbfs/inode.c | inode->i_atime = finfo.atime; |
inode | 395 | fs/smbfs/inode.c | smb_invalid_dir_cache((unsigned long)(SMB_INOP(inode)->dir)); |
inode | 17 | fs/smbfs/ioctl.c | smb_ioctl (struct inode * inode, struct file * filp, |
inode | 28 | fs/smbfs/ioctl.c | put_fs_word(SMB_SERVER(inode)->m.mounted_uid, (uid_t*) arg); |
inode | 30 | fs/smbfs/mmap.c | struct inode * inode = area->vm_inode; |
inode | 50 | fs/smbfs/mmap.c | n = SMB_SERVER(inode)->max_xmit - SMB_HEADER_LEN - 5 * 2 - 3 - 10; |
inode | 52 | fs/smbfs/mmap.c | if (smb_make_open(inode, O_RDONLY) < 0) { |
inode | 67 | fs/smbfs/mmap.c | result = smb_proc_read(SMB_SERVER(inode), |
inode | 68 | fs/smbfs/mmap.c | SMB_FINFO(inode), pos, hunk, |
inode | 104 | fs/smbfs/mmap.c | smb_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 111 | fs/smbfs/mmap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 113 | fs/smbfs/mmap.c | if (!IS_RDONLY(inode)) { |
inode | 114 | fs/smbfs/mmap.c | inode->i_atime = CURRENT_TIME; |
inode | 115 | fs/smbfs/mmap.c | inode->i_dirt = 1; |
inode | 118 | fs/smbfs/mmap.c | vma->vm_inode = inode; |
inode | 119 | fs/smbfs/mmap.c | inode->i_count++; |
inode | 940 | fs/smbfs/proc.c | smb_proc_readdir_short(struct smb_server *server, struct inode *dir, int fpos, |
inode | 1144 | fs/smbfs/proc.c | smb_proc_readdir_long(struct smb_server *server, struct inode *dir, int fpos, |
inode | 1372 | fs/smbfs/proc.c | smb_proc_readdir(struct smb_server *server, struct inode *dir, int fpos, |
inode | 1535 | fs/smbfs/proc.c | smb_proc_setattr(struct smb_server *server, struct inode *inode, |
inode | 1538 | fs/smbfs/proc.c | struct smb_dirent *finfo = SMB_FINFO(inode); |
inode | 1542 | fs/smbfs/proc.c | if ((result = smb_make_open(inode, O_RDWR)) < 0) |
inode | 110 | fs/smbfs/sock.c | struct inode *inode; |
inode | 116 | fs/smbfs/sock.c | || ((inode = file->f_inode) == NULL) |
inode | 117 | fs/smbfs/sock.c | || (!S_ISSOCK(inode->i_mode))) { |
inode | 124 | fs/smbfs/sock.c | sock = &(inode->u.socket_i); |
inode | 158 | fs/smbfs/sock.c | struct inode *inode; |
inode | 164 | fs/smbfs/sock.c | || ((inode = file->f_inode) == NULL) |
inode | 165 | fs/smbfs/sock.c | || (!S_ISSOCK(inode->i_mode))) { |
inode | 172 | fs/smbfs/sock.c | sock = &(inode->u.socket_i); |
inode | 437 | fs/smbfs/sock.c | struct inode *inode; |
inode | 443 | fs/smbfs/sock.c | if ((inode = file->f_inode) == NULL) |
inode | 445 | fs/smbfs/sock.c | return &(inode->u.socket_i); |
inode | 23 | fs/stat.c | static void cp_old_stat(struct inode * inode, struct old_stat * statbuf) |
inode | 29 | fs/stat.c | tmp.st_dev = kdev_t_to_nr(inode->i_dev); |
inode | 30 | fs/stat.c | tmp.st_ino = inode->i_ino; |
inode | 31 | fs/stat.c | tmp.st_mode = inode->i_mode; |
inode | 32 | fs/stat.c | tmp.st_nlink = inode->i_nlink; |
inode | 33 | fs/stat.c | tmp.st_uid = inode->i_uid; |
inode | 34 | fs/stat.c | tmp.st_gid = inode->i_gid; |
inode | 35 | fs/stat.c | tmp.st_rdev = kdev_t_to_nr(inode->i_rdev); |
inode | 36 | fs/stat.c | tmp.st_size = inode->i_size; |
inode | 37 | fs/stat.c | if (inode->i_pipe) |
inode | 38 | fs/stat.c | tmp.st_size = PIPE_SIZE(*inode); |
inode | 39 | fs/stat.c | tmp.st_atime = inode->i_atime; |
inode | 40 | fs/stat.c | tmp.st_mtime = inode->i_mtime; |
inode | 41 | fs/stat.c | tmp.st_ctime = inode->i_ctime; |
inode | 47 | fs/stat.c | static void cp_new_stat(struct inode * inode, struct new_stat * statbuf) |
inode | 53 | fs/stat.c | tmp.st_dev = kdev_t_to_nr(inode->i_dev); |
inode | 54 | fs/stat.c | tmp.st_ino = inode->i_ino; |
inode | 55 | fs/stat.c | tmp.st_mode = inode->i_mode; |
inode | 56 | fs/stat.c | tmp.st_nlink = inode->i_nlink; |
inode | 57 | fs/stat.c | tmp.st_uid = inode->i_uid; |
inode | 58 | fs/stat.c | tmp.st_gid = inode->i_gid; |
inode | 59 | fs/stat.c | tmp.st_rdev = kdev_t_to_nr(inode->i_rdev); |
inode | 60 | fs/stat.c | tmp.st_size = inode->i_size; |
inode | 61 | fs/stat.c | if (inode->i_pipe) |
inode | 62 | fs/stat.c | tmp.st_size = PIPE_SIZE(*inode); |
inode | 63 | fs/stat.c | tmp.st_atime = inode->i_atime; |
inode | 64 | fs/stat.c | tmp.st_mtime = inode->i_mtime; |
inode | 65 | fs/stat.c | tmp.st_ctime = inode->i_ctime; |
inode | 84 | fs/stat.c | if (!inode->i_blksize) { |
inode | 99 | fs/stat.c | tmp.st_blocks = inode->i_blocks; |
inode | 100 | fs/stat.c | tmp.st_blksize = inode->i_blksize; |
inode | 112 | fs/stat.c | struct inode * inode; |
inode | 118 | fs/stat.c | error = namei(filename,&inode); |
inode | 121 | fs/stat.c | cp_old_stat(inode,statbuf); |
inode | 122 | fs/stat.c | iput(inode); |
inode | 129 | fs/stat.c | struct inode * inode; |
inode | 135 | fs/stat.c | error = namei(filename,&inode); |
inode | 138 | fs/stat.c | cp_new_stat(inode,statbuf); |
inode | 139 | fs/stat.c | iput(inode); |
inode | 151 | fs/stat.c | struct inode * inode; |
inode | 157 | fs/stat.c | error = lnamei(filename,&inode); |
inode | 160 | fs/stat.c | cp_old_stat(inode,statbuf); |
inode | 161 | fs/stat.c | iput(inode); |
inode | 169 | fs/stat.c | struct inode * inode; |
inode | 175 | fs/stat.c | error = lnamei(filename,&inode); |
inode | 178 | fs/stat.c | cp_new_stat(inode,statbuf); |
inode | 179 | fs/stat.c | iput(inode); |
inode | 192 | fs/stat.c | struct inode * inode; |
inode | 198 | fs/stat.c | if (fd >= NR_OPEN || !(f=current->files->fd[fd]) || !(inode=f->f_inode)) |
inode | 200 | fs/stat.c | cp_old_stat(inode,statbuf); |
inode | 209 | fs/stat.c | struct inode * inode; |
inode | 215 | fs/stat.c | if (fd >= NR_OPEN || !(f=current->files->fd[fd]) || !(inode=f->f_inode)) |
inode | 217 | fs/stat.c | cp_new_stat(inode,statbuf); |
inode | 223 | fs/stat.c | struct inode * inode; |
inode | 231 | fs/stat.c | error = lnamei(path,&inode); |
inode | 234 | fs/stat.c | if (!inode->i_op || !inode->i_op->readlink) { |
inode | 235 | fs/stat.c | iput(inode); |
inode | 238 | fs/stat.c | return inode->i_op->readlink(inode,buf,bufsiz); |
inode | 48 | fs/super.c | extern void blkdev_release (struct inode *); |
inode | 632 | fs/super.c | struct inode * inode; |
inode | 635 | fs/super.c | struct inode dummy_inode; |
inode | 639 | fs/super.c | retval = namei(name, &inode); |
inode | 641 | fs/super.c | retval = lnamei(name, &inode); |
inode | 645 | fs/super.c | if (S_ISBLK(inode->i_mode)) { |
inode | 646 | fs/super.c | dev = inode->i_rdev; |
inode | 647 | fs/super.c | if (IS_NODEV(inode)) { |
inode | 648 | fs/super.c | iput(inode); |
inode | 652 | fs/super.c | if (!inode->i_sb || inode != inode->i_sb->s_mounted) { |
inode | 653 | fs/super.c | iput(inode); |
inode | 656 | fs/super.c | dev = inode->i_sb->s_dev; |
inode | 657 | fs/super.c | iput(inode); |
inode | 660 | fs/super.c | inode = &dummy_inode; |
inode | 663 | fs/super.c | iput(inode); |
inode | 670 | fs/super.c | blkdev_release (inode); |
inode | 675 | fs/super.c | if (inode != &dummy_inode) |
inode | 676 | fs/super.c | iput(inode); |
inode | 695 | fs/super.c | struct inode * dir_i; |
inode | 771 | fs/super.c | struct inode *dir_i; |
inode | 830 | fs/super.c | struct inode * inode; |
inode | 861 | fs/super.c | retval = namei(dev_name, &inode); |
inode | 864 | fs/super.c | if (!S_ISBLK(inode->i_mode)) { |
inode | 865 | fs/super.c | iput(inode); |
inode | 868 | fs/super.c | if (IS_NODEV(inode)) { |
inode | 869 | fs/super.c | iput(inode); |
inode | 872 | fs/super.c | dev = inode->i_rdev; |
inode | 874 | fs/super.c | iput(inode); |
inode | 879 | fs/super.c | iput(inode); |
inode | 885 | fs/super.c | dummy.f_inode = inode; |
inode | 887 | fs/super.c | retval = fops->open(inode, &dummy); |
inode | 889 | fs/super.c | iput(inode); |
inode | 897 | fs/super.c | inode = NULL; |
inode | 904 | fs/super.c | iput(inode); |
inode | 911 | fs/super.c | fops->release(inode, NULL); |
inode | 912 | fs/super.c | iput(inode); |
inode | 921 | fs/super.c | struct inode * inode, d_inode; |
inode | 940 | fs/super.c | inode = sb->s_mounted; |
inode | 941 | fs/super.c | inode->i_count += 3 ; |
inode | 942 | fs/super.c | sb->s_covered = inode; |
inode | 946 | fs/super.c | current->fs->pwd = inode; |
inode | 947 | fs/super.c | current->fs->root = inode; |
inode | 999 | fs/super.c | inode = sb->s_mounted; |
inode | 1000 | fs/super.c | inode->i_count += 3 ; /* NOTE! it is logically used 4 times, not 1 */ |
inode | 1001 | fs/super.c | sb->s_covered = inode; |
inode | 1003 | fs/super.c | current->fs->pwd = inode; |
inode | 1004 | fs/super.c | current->fs->root = inode; |
inode | 1034 | fs/super.c | struct inode *old_root,*old_pwd,*inode; |
inode | 1045 | fs/super.c | error = namei(put_old,&inode); |
inode | 1046 | fs/super.c | if (error) inode = NULL; |
inode | 1048 | fs/super.c | if (!error && (inode->i_count != 1 || inode->i_mount)) error = -EBUSY; |
inode | 1049 | fs/super.c | if (!error && !S_ISDIR(inode->i_mode)) error = -ENOTDIR; |
inode | 1055 | fs/super.c | if (inode) iput(inode); |
inode | 1073 | fs/super.c | vfsmnt->mnt_sb->s_covered = inode; |
inode | 1076 | fs/super.c | inode->i_mount = old_root; |
inode | 24 | fs/sysv/dir.c | static int sysv_dir_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 29 | fs/sysv/dir.c | static int sysv_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 67 | fs/sysv/dir.c | static int sysv_readdir(struct inode * inode, struct file * filp, |
inode | 76 | fs/sysv/dir.c | if (!inode || !(sb = inode->i_sb) || !S_ISDIR(inode->i_mode)) |
inode | 80 | fs/sysv/dir.c | while (filp->f_pos < inode->i_size) { |
inode | 82 | fs/sysv/dir.c | bh = sysv_file_bread(inode, filp->f_pos >> sb->sv_block_size_bits, 0); |
inode | 88 | fs/sysv/dir.c | while (offset < sb->sv_block_size && filp->f_pos < inode->i_size) { |
inode | 90 | fs/sysv/dir.c | if (de->inode) { |
inode | 96 | fs/sysv/dir.c | if (sde.inode > inode->i_sb->sv_ninodes) |
inode | 99 | fs/sysv/dir.c | kdevname(inode->i_dev), |
inode | 100 | fs/sysv/dir.c | inode->i_ino, (off_t) filp->f_pos, sde.inode); |
inode | 103 | fs/sysv/dir.c | if (filldir(dirent, sde.name, i, filp->f_pos, sde.inode) < 0) { |
inode | 36 | fs/sysv/file.c | static int sysv_file_write(struct inode *, struct file *, const char *, int); |
inode | 75 | fs/sysv/file.c | int sysv_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 77 | fs/sysv/file.c | struct super_block * sb = inode->i_sb; |
inode | 87 | fs/sysv/file.c | if (!inode) { |
inode | 91 | fs/sysv/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 92 | fs/sysv/file.c | printk("sysv_file_read: mode = %07o\n",inode->i_mode); |
inode | 96 | fs/sysv/file.c | size = inode->i_size; |
inode | 112 | fs/sysv/file.c | blocks += read_ahead[MAJOR(inode->i_dev)] >> (sb->sv_block_size_bits - 9); |
inode | 133 | fs/sysv/file.c | *bhb = sysv_getblk(inode, block++, 0); |
inode | 195 | fs/sysv/file.c | if (!IS_RDONLY(inode)) { |
inode | 196 | fs/sysv/file.c | inode->i_atime = CURRENT_TIME; |
inode | 197 | fs/sysv/file.c | inode->i_dirt = 1; |
inode | 202 | fs/sysv/file.c | static int sysv_file_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 204 | fs/sysv/file.c | struct super_block * sb = inode->i_sb; |
inode | 210 | fs/sysv/file.c | if (!inode) { |
inode | 214 | fs/sysv/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 215 | fs/sysv/file.c | printk("sysv_file_write: mode = %07o\n",inode->i_mode); |
inode | 226 | fs/sysv/file.c | pos = inode->i_size; |
inode | 231 | fs/sysv/file.c | bh = sysv_getblk (inode, pos >> sb->sv_block_size_bits, 1); |
inode | 253 | fs/sysv/file.c | update_vm_cache(inode, pos, p, c); |
inode | 255 | fs/sysv/file.c | if (pos > inode->i_size) { |
inode | 256 | fs/sysv/file.c | inode->i_size = pos; |
inode | 257 | fs/sysv/file.c | inode->i_dirt = 1; |
inode | 265 | fs/sysv/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 267 | fs/sysv/file.c | inode->i_dirt = 1; |
inode | 29 | fs/sysv/fsync.c | static int sync_block (struct inode * inode, unsigned long * blockp, int convert, int wait) |
inode | 40 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 41 | fs/sysv/fsync.c | bh = sv_get_hash_table(sb, inode->i_dev, block); |
inode | 62 | fs/sysv/fsync.c | static int sync_iblock (struct inode * inode, unsigned long * iblockp, int convert, |
inode | 74 | fs/sysv/fsync.c | rc = sync_block (inode, iblockp, convert, wait); |
inode | 77 | fs/sysv/fsync.c | *bh = sv_bread(inode->i_sb, inode->i_dev, block); |
inode | 89 | fs/sysv/fsync.c | static int sync_direct(struct inode *inode, int wait) |
inode | 95 | fs/sysv/fsync.c | rc = sync_block (inode, inode->u.sysv_i.i_data + i, 0, wait); |
inode | 104 | fs/sysv/fsync.c | static int sync_indirect(struct inode *inode, unsigned long *iblockp, int convert, int wait) |
inode | 111 | fs/sysv/fsync.c | rc = sync_iblock (inode, iblockp, convert, &ind_bh, wait); |
inode | 115 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 117 | fs/sysv/fsync.c | rc = sync_block (inode, |
inode | 129 | fs/sysv/fsync.c | static int sync_dindirect(struct inode *inode, unsigned long *diblockp, int convert, |
inode | 137 | fs/sysv/fsync.c | rc = sync_iblock (inode, diblockp, convert, &dind_bh, wait); |
inode | 141 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 143 | fs/sysv/fsync.c | rc = sync_indirect (inode, |
inode | 155 | fs/sysv/fsync.c | static int sync_tindirect(struct inode *inode, unsigned long *tiblockp, int convert, |
inode | 163 | fs/sysv/fsync.c | rc = sync_iblock (inode, tiblockp, convert, &tind_bh, wait); |
inode | 167 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 169 | fs/sysv/fsync.c | rc = sync_dindirect (inode, |
inode | 181 | fs/sysv/fsync.c | int sysv_sync_file(struct inode * inode, struct file * file) |
inode | 185 | fs/sysv/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 186 | fs/sysv/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 190 | fs/sysv/fsync.c | err |= sync_direct(inode, wait); |
inode | 191 | fs/sysv/fsync.c | err |= sync_indirect(inode, inode->u.sysv_i.i_data+10, 0, wait); |
inode | 192 | fs/sysv/fsync.c | err |= sync_dindirect(inode, inode->u.sysv_i.i_data+11, 0, wait); |
inode | 193 | fs/sysv/fsync.c | err |= sync_tindirect(inode, inode->u.sysv_i.i_data+12, 0, wait); |
inode | 195 | fs/sysv/fsync.c | err |= sysv_sync_inode (inode); |
inode | 52 | fs/sysv/ialloc.c | void sysv_free_inode(struct inode * inode) |
inode | 59 | fs/sysv/ialloc.c | if (!inode) |
inode | 61 | fs/sysv/ialloc.c | if (!inode->i_dev) { |
inode | 65 | fs/sysv/ialloc.c | if (inode->i_count != 1) { |
inode | 66 | fs/sysv/ialloc.c | printk("sysv_free_inode: inode has count=%d\n", inode->i_count); |
inode | 69 | fs/sysv/ialloc.c | if (inode->i_nlink) { |
inode | 70 | fs/sysv/ialloc.c | printk("sysv_free_inode: inode has nlink=%d\n", inode->i_nlink); |
inode | 73 | fs/sysv/ialloc.c | if (!(sb = inode->i_sb)) { |
inode | 77 | fs/sysv/ialloc.c | ino = inode->i_ino; |
inode | 82 | fs/sysv/ialloc.c | if (!(bh = sv_bread(sb, inode->i_dev, sb->sv_firstinodezone + ((ino-1) >> sb->sv_inodes_per_block_bits)))) { |
inode | 84 | fs/sysv/ialloc.c | "%s\n", kdevname(inode->i_dev)); |
inode | 85 | fs/sysv/ialloc.c | clear_inode(inode); |
inode | 100 | fs/sysv/ialloc.c | clear_inode(inode); |
inode | 103 | fs/sysv/ialloc.c | struct inode * sysv_new_inode(const struct inode * dir) |
inode | 105 | fs/sysv/ialloc.c | struct inode * inode; |
inode | 111 | fs/sysv/ialloc.c | if (!dir || !(inode = get_empty_inode())) |
inode | 114 | fs/sysv/ialloc.c | inode->i_sb = sb; |
inode | 115 | fs/sysv/ialloc.c | inode->i_flags = inode->i_sb->s_flags; |
inode | 141 | fs/sysv/ialloc.c | iput(inode); |
inode | 152 | fs/sysv/ialloc.c | inode->i_count = 1; |
inode | 153 | fs/sysv/ialloc.c | inode->i_nlink = 1; |
inode | 154 | fs/sysv/ialloc.c | inode->i_dev = sb->s_dev; |
inode | 155 | fs/sysv/ialloc.c | inode->i_uid = current->fsuid; |
inode | 156 | fs/sysv/ialloc.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 157 | fs/sysv/ialloc.c | inode->i_dirt = 1; |
inode | 158 | fs/sysv/ialloc.c | inode->i_ino = ino; |
inode | 159 | fs/sysv/ialloc.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 160 | fs/sysv/ialloc.c | inode->i_op = NULL; |
inode | 161 | fs/sysv/ialloc.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 162 | fs/sysv/ialloc.c | insert_inode_hash(inode); |
inode | 164 | fs/sysv/ialloc.c | inode->i_mode = 0; /* for sysv_write_inode() */ |
inode | 165 | fs/sysv/ialloc.c | inode->i_size = 0; /* ditto */ |
inode | 166 | fs/sysv/ialloc.c | sysv_write_inode(inode); /* ensure inode not allocated again */ |
inode | 168 | fs/sysv/ialloc.c | inode->i_dirt = 1; /* cleared by sysv_write_inode() */ |
inode | 174 | fs/sysv/ialloc.c | return inode; |
inode | 35 | fs/sysv/inode.c | void sysv_put_inode(struct inode *inode) |
inode | 37 | fs/sysv/inode.c | if (inode->i_nlink) |
inode | 39 | fs/sysv/inode.c | inode->i_size = 0; |
inode | 40 | fs/sysv/inode.c | sysv_truncate(inode); |
inode | 41 | fs/sysv/inode.c | sysv_free_inode(inode); |
inode | 554 | fs/sysv/inode.c | static inline int inode_bmap(struct super_block * sb, struct inode * inode, int nr) |
inode | 556 | fs/sysv/inode.c | int tmp = inode->u.sysv_i.i_data[nr]; |
inode | 577 | fs/sysv/inode.c | int sysv_bmap(struct inode * inode,int block_nr) |
inode | 580 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 586 | fs/sysv/inode.c | return inode_bmap(sb,inode,block); |
inode | 590 | fs/sysv/inode.c | i = inode_bmap(sb,inode,10); |
inode | 593 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 598 | fs/sysv/inode.c | i = inode_bmap(sb,inode,11); |
inode | 601 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 605 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 610 | fs/sysv/inode.c | i = inode_bmap(sb,inode,12); |
inode | 613 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 617 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 621 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 637 | fs/sysv/inode.c | static struct buffer_head * inode_getblk(struct inode * inode, int nr, int create) |
inode | 644 | fs/sysv/inode.c | sb = inode->i_sb; |
inode | 645 | fs/sysv/inode.c | p = inode->u.sysv_i.i_data + nr; |
inode | 649 | fs/sysv/inode.c | result = sv_getblk(sb, inode->i_dev, tmp); |
inode | 660 | fs/sysv/inode.c | result = sv_getblk(sb, inode->i_dev, tmp); |
inode | 667 | fs/sysv/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 668 | fs/sysv/inode.c | inode->i_dirt = 1; |
inode | 672 | fs/sysv/inode.c | static struct buffer_head * block_getblk(struct inode * inode, |
inode | 690 | fs/sysv/inode.c | sb = inode->i_sb; |
inode | 726 | fs/sysv/inode.c | struct buffer_head * sysv_getblk(struct inode * inode, unsigned int block, int create) |
inode | 728 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 732 | fs/sysv/inode.c | return inode_getblk(inode,block,create); |
inode | 735 | fs/sysv/inode.c | bh = inode_getblk(inode,10,create); |
inode | 736 | fs/sysv/inode.c | return block_getblk(inode, bh, block, create); |
inode | 740 | fs/sysv/inode.c | bh = inode_getblk(inode,11,create); |
inode | 741 | fs/sysv/inode.c | bh = block_getblk(inode, bh, block >> sb->sv_ind_per_block_bits, create); |
inode | 742 | fs/sysv/inode.c | return block_getblk(inode, bh, block & sb->sv_ind_per_block_1, create); |
inode | 746 | fs/sysv/inode.c | bh = inode_getblk(inode,12,create); |
inode | 747 | fs/sysv/inode.c | bh = block_getblk(inode, bh, block >> sb->sv_ind_per_block_2_bits, create); |
inode | 748 | fs/sysv/inode.c | bh = block_getblk(inode, bh, (block >> sb->sv_ind_per_block_bits) & sb->sv_ind_per_block_1, create); |
inode | 749 | fs/sysv/inode.c | return block_getblk(inode, bh, block & sb->sv_ind_per_block_1, create); |
inode | 759 | fs/sysv/inode.c | struct buffer_head * sysv_file_bread(struct inode * inode, int block, int create) |
inode | 763 | fs/sysv/inode.c | bh = sysv_getblk(inode,block,create); |
inode | 799 | fs/sysv/inode.c | void sysv_read_inode(struct inode * inode) |
inode | 801 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 807 | fs/sysv/inode.c | ino = inode->i_ino; |
inode | 808 | fs/sysv/inode.c | inode->i_op = NULL; |
inode | 809 | fs/sysv/inode.c | inode->i_mode = 0; |
inode | 813 | fs/sysv/inode.c | kdevname(inode->i_dev), ino); |
inode | 817 | fs/sysv/inode.c | if (!(bh = sv_bread(sb,inode->i_dev,block))) { |
inode | 820 | fs/sysv/inode.c | kdevname(inode->i_dev)); |
inode | 828 | fs/sysv/inode.c | inode->i_mode = mode; |
inode | 829 | fs/sysv/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 830 | fs/sysv/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 831 | fs/sysv/inode.c | inode->i_nlink = raw_inode->i_nlink; |
inode | 833 | fs/sysv/inode.c | inode->i_size = from_coh_ulong(raw_inode->i_size); |
inode | 834 | fs/sysv/inode.c | inode->i_atime = from_coh_ulong(raw_inode->i_atime); |
inode | 835 | fs/sysv/inode.c | inode->i_mtime = from_coh_ulong(raw_inode->i_mtime); |
inode | 836 | fs/sysv/inode.c | inode->i_ctime = from_coh_ulong(raw_inode->i_ctime); |
inode | 838 | fs/sysv/inode.c | inode->i_size = raw_inode->i_size; |
inode | 839 | fs/sysv/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 840 | fs/sysv/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 841 | fs/sysv/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 843 | fs/sysv/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 844 | fs/sysv/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 845 | fs/sysv/inode.c | inode->i_rdev = to_kdev_t(raw_inode->i_a.i_rdev); |
inode | 849 | fs/sysv/inode.c | inode->u.sysv_i.i_data[block] = |
inode | 853 | fs/sysv/inode.c | inode->u.sysv_i.i_data[block] = |
inode | 856 | fs/sysv/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 857 | fs/sysv/inode.c | inode->i_op = &sysv_file_inode_operations; |
inode | 858 | fs/sysv/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 859 | fs/sysv/inode.c | inode->i_op = &sysv_dir_inode_operations; |
inode | 860 | fs/sysv/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 861 | fs/sysv/inode.c | inode->i_op = &sysv_symlink_inode_operations; |
inode | 862 | fs/sysv/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 863 | fs/sysv/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 864 | fs/sysv/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 865 | fs/sysv/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 866 | fs/sysv/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 867 | fs/sysv/inode.c | init_fifo(inode); |
inode | 871 | fs/sysv/inode.c | extern int sysv_notify_change(struct inode *inode, struct iattr *attr) |
inode | 875 | fs/sysv/inode.c | if ((error = inode_change_ok(inode, attr)) != 0) |
inode | 879 | fs/sysv/inode.c | if (inode->i_sb->sv_kludge_symlinks) |
inode | 883 | fs/sysv/inode.c | inode_setattr(inode, attr); |
inode | 888 | fs/sysv/inode.c | static struct buffer_head * sysv_update_inode(struct inode * inode) |
inode | 890 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 896 | fs/sysv/inode.c | ino = inode->i_ino; |
inode | 900 | fs/sysv/inode.c | kdevname(inode->i_dev), ino); |
inode | 901 | fs/sysv/inode.c | inode->i_dirt = 0; |
inode | 905 | fs/sysv/inode.c | if (!(bh = sv_bread(sb,inode->i_dev,block))) { |
inode | 907 | fs/sysv/inode.c | inode->i_dirt = 0; |
inode | 911 | fs/sysv/inode.c | mode = inode->i_mode; |
inode | 915 | fs/sysv/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 916 | fs/sysv/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 917 | fs/sysv/inode.c | raw_inode->i_nlink = inode->i_nlink; |
inode | 919 | fs/sysv/inode.c | raw_inode->i_size = to_coh_ulong(inode->i_size); |
inode | 920 | fs/sysv/inode.c | raw_inode->i_atime = to_coh_ulong(inode->i_atime); |
inode | 921 | fs/sysv/inode.c | raw_inode->i_mtime = to_coh_ulong(inode->i_mtime); |
inode | 922 | fs/sysv/inode.c | raw_inode->i_ctime = to_coh_ulong(inode->i_ctime); |
inode | 924 | fs/sysv/inode.c | raw_inode->i_size = inode->i_size; |
inode | 925 | fs/sysv/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 926 | fs/sysv/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 927 | fs/sysv/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 929 | fs/sysv/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 930 | fs/sysv/inode.c | raw_inode->i_a.i_rdev = kdev_t_to_nr(inode->i_rdev); /* write 2 or 3 bytes ?? */ |
inode | 934 | fs/sysv/inode.c | coh_write3byte(&raw_inode->i_a.i_addb[3*block],inode->u.sysv_i.i_data[block]); |
inode | 937 | fs/sysv/inode.c | write3byte(&raw_inode->i_a.i_addb[3*block],inode->u.sysv_i.i_data[block]); |
inode | 938 | fs/sysv/inode.c | inode->i_dirt=0; |
inode | 943 | fs/sysv/inode.c | void sysv_write_inode(struct inode * inode) |
inode | 946 | fs/sysv/inode.c | bh = sysv_update_inode(inode); |
inode | 950 | fs/sysv/inode.c | int sysv_sync_inode(struct inode * inode) |
inode | 955 | fs/sysv/inode.c | bh = sysv_update_inode(inode); |
inode | 963 | fs/sysv/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 44 | fs/sysv/namei.c | if (!de->inode || len > SYSV_NAMELEN) |
inode | 60 | fs/sysv/namei.c | static struct buffer_head * sysv_find_entry(struct inode * dir, |
inode | 103 | fs/sysv/namei.c | int sysv_lookup(struct inode * dir,const char * name, int len, |
inode | 104 | fs/sysv/namei.c | struct inode ** result) |
inode | 121 | fs/sysv/namei.c | ino = de->inode; |
inode | 141 | fs/sysv/namei.c | static int sysv_add_entry(struct inode * dir, |
inode | 176 | fs/sysv/namei.c | de->inode = 0; |
inode | 180 | fs/sysv/namei.c | if (de->inode) { |
inode | 204 | fs/sysv/namei.c | int sysv_create(struct inode * dir,const char * name, int len, int mode, |
inode | 205 | fs/sysv/namei.c | struct inode ** result) |
inode | 208 | fs/sysv/namei.c | struct inode * inode; |
inode | 215 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
inode | 216 | fs/sysv/namei.c | if (!inode) { |
inode | 220 | fs/sysv/namei.c | inode->i_op = &sysv_file_inode_operations; |
inode | 221 | fs/sysv/namei.c | inode->i_mode = mode; |
inode | 222 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 225 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 226 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 227 | fs/sysv/namei.c | iput(inode); |
inode | 231 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 235 | fs/sysv/namei.c | *result = inode; |
inode | 239 | fs/sysv/namei.c | int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
inode | 242 | fs/sysv/namei.c | struct inode * inode; |
inode | 254 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
inode | 255 | fs/sysv/namei.c | if (!inode) { |
inode | 259 | fs/sysv/namei.c | inode->i_uid = current->fsuid; |
inode | 260 | fs/sysv/namei.c | inode->i_mode = mode; |
inode | 261 | fs/sysv/namei.c | inode->i_op = NULL; |
inode | 262 | fs/sysv/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 263 | fs/sysv/namei.c | inode->i_op = &sysv_file_inode_operations; |
inode | 264 | fs/sysv/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 265 | fs/sysv/namei.c | inode->i_op = &sysv_dir_inode_operations; |
inode | 267 | fs/sysv/namei.c | inode->i_mode |= S_ISGID; |
inode | 269 | fs/sysv/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 270 | fs/sysv/namei.c | inode->i_op = &sysv_symlink_inode_operations; |
inode | 271 | fs/sysv/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 272 | fs/sysv/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 273 | fs/sysv/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 274 | fs/sysv/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 275 | fs/sysv/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 276 | fs/sysv/namei.c | init_fifo(inode); |
inode | 278 | fs/sysv/namei.c | inode->i_rdev = to_kdev_t(rdev); |
inode | 279 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 282 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 283 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 284 | fs/sysv/namei.c | iput(inode); |
inode | 288 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 292 | fs/sysv/namei.c | iput(inode); |
inode | 296 | fs/sysv/namei.c | int sysv_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 299 | fs/sysv/namei.c | struct inode * inode; |
inode | 317 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
inode | 318 | fs/sysv/namei.c | if (!inode) { |
inode | 322 | fs/sysv/namei.c | inode->i_op = &sysv_dir_inode_operations; |
inode | 323 | fs/sysv/namei.c | inode->i_size = 2 * SYSV_DIRSIZE; |
inode | 324 | fs/sysv/namei.c | dir_block = sysv_file_bread(inode,0,1); |
inode | 327 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 328 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 329 | fs/sysv/namei.c | iput(inode); |
inode | 333 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 336 | fs/sysv/namei.c | de->inode = dir->i_ino; |
inode | 338 | fs/sysv/namei.c | inode->i_nlink = 2; |
inode | 341 | fs/sysv/namei.c | inode->i_mode = S_IFDIR | (mode & 0777 & ~current->fs->umask); |
inode | 343 | fs/sysv/namei.c | inode->i_mode |= S_ISGID; |
inode | 344 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 348 | fs/sysv/namei.c | inode->i_nlink=0; |
inode | 349 | fs/sysv/namei.c | iput(inode); |
inode | 352 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 357 | fs/sysv/namei.c | iput(inode); |
inode | 365 | fs/sysv/namei.c | static int empty_dir(struct inode * inode) |
inode | 372 | fs/sysv/namei.c | if (!inode) |
inode | 377 | fs/sysv/namei.c | if (inode->i_size % SYSV_DIRSIZE) |
inode | 379 | fs/sysv/namei.c | if (inode->i_size < pos) |
inode | 381 | fs/sysv/namei.c | bh = sysv_file_bread(inode,0,0); |
inode | 385 | fs/sysv/namei.c | if (!de->inode || strcmp(de->name,".")) |
inode | 388 | fs/sysv/namei.c | if (!de->inode || strcmp(de->name,"..")) |
inode | 390 | fs/sysv/namei.c | sb = inode->i_sb; |
inode | 391 | fs/sysv/namei.c | while (pos < inode->i_size) { |
inode | 393 | fs/sysv/namei.c | bh = sysv_file_bread(inode,block,0); |
inode | 403 | fs/sysv/namei.c | if (de->inode) { |
inode | 418 | fs/sysv/namei.c | kdevname(inode->i_dev)); |
inode | 422 | fs/sysv/namei.c | int sysv_rmdir(struct inode * dir, const char * name, int len) |
inode | 425 | fs/sysv/namei.c | struct inode * inode; |
inode | 429 | fs/sysv/namei.c | inode = NULL; |
inode | 435 | fs/sysv/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 438 | fs/sysv/namei.c | current->fsuid != inode->i_uid && |
inode | 441 | fs/sysv/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 443 | fs/sysv/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 445 | fs/sysv/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 449 | fs/sysv/namei.c | if (!empty_dir(inode)) { |
inode | 453 | fs/sysv/namei.c | if (de->inode != inode->i_ino) { |
inode | 457 | fs/sysv/namei.c | if (inode->i_count > 1) { |
inode | 461 | fs/sysv/namei.c | if (inode->i_nlink != 2) |
inode | 462 | fs/sysv/namei.c | printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); |
inode | 463 | fs/sysv/namei.c | de->inode = 0; |
inode | 465 | fs/sysv/namei.c | inode->i_nlink=0; |
inode | 466 | fs/sysv/namei.c | inode->i_dirt=1; |
inode | 468 | fs/sysv/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 473 | fs/sysv/namei.c | iput(inode); |
inode | 478 | fs/sysv/namei.c | int sysv_unlink(struct inode * dir, const char * name, int len) |
inode | 481 | fs/sysv/namei.c | struct inode * inode; |
inode | 487 | fs/sysv/namei.c | inode = NULL; |
inode | 491 | fs/sysv/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 494 | fs/sysv/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 496 | fs/sysv/namei.c | if (de->inode != inode->i_ino) { |
inode | 497 | fs/sysv/namei.c | iput(inode); |
inode | 504 | fs/sysv/namei.c | current->fsuid != inode->i_uid && |
inode | 507 | fs/sysv/namei.c | if (de->inode != inode->i_ino) { |
inode | 511 | fs/sysv/namei.c | if (!inode->i_nlink) { |
inode | 513 | fs/sysv/namei.c | kdevname(inode->i_dev), |
inode | 514 | fs/sysv/namei.c | inode->i_ino, inode->i_nlink); |
inode | 515 | fs/sysv/namei.c | inode->i_nlink=1; |
inode | 517 | fs/sysv/namei.c | de->inode = 0; |
inode | 521 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 522 | fs/sysv/namei.c | inode->i_ctime = dir->i_ctime; |
inode | 523 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 527 | fs/sysv/namei.c | iput(inode); |
inode | 532 | fs/sysv/namei.c | int sysv_symlink(struct inode * dir, const char * name, int len, const char * symname) |
inode | 535 | fs/sysv/namei.c | struct inode * inode; |
inode | 543 | fs/sysv/namei.c | if (!(inode = sysv_new_inode(dir))) { |
inode | 547 | fs/sysv/namei.c | inode->i_mode = S_IFLNK | 0777; |
inode | 548 | fs/sysv/namei.c | inode->i_op = &sysv_symlink_inode_operations; |
inode | 549 | fs/sysv/namei.c | name_block = sysv_file_bread(inode,0,1); |
inode | 552 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 553 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 554 | fs/sysv/namei.c | iput(inode); |
inode | 557 | fs/sysv/namei.c | sb = inode->i_sb; |
inode | 565 | fs/sysv/namei.c | inode->i_size = i; |
inode | 566 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 569 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 570 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 571 | fs/sysv/namei.c | iput(inode); |
inode | 578 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 579 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 580 | fs/sysv/namei.c | iput(inode); |
inode | 584 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 588 | fs/sysv/namei.c | iput(inode); |
inode | 592 | fs/sysv/namei.c | int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
inode | 621 | fs/sysv/namei.c | de->inode = oldinode->i_ino; |
inode | 633 | fs/sysv/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 658 | fs/sysv/namei.c | (((struct sysv_dir_entry *) ((buffer) + 1*SYSV_DIRSIZE))->inode) |
inode | 670 | fs/sysv/namei.c | static int do_sysv_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 671 | fs/sysv/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 673 | fs/sysv/namei.c | struct inode * old_inode, * new_inode; |
inode | 694 | fs/sysv/namei.c | old_inode = __iget(old_dir->i_sb, old_de->inode, 0); /* don't cross mnt-points */ |
inode | 704 | fs/sysv/namei.c | new_inode = __iget(new_dir->i_sb, new_de->inode, 0); |
inode | 756 | fs/sysv/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 758 | fs/sysv/namei.c | if (new_de->inode && !new_inode) |
inode | 760 | fs/sysv/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 763 | fs/sysv/namei.c | old_de->inode = 0; |
inode | 764 | fs/sysv/namei.c | new_de->inode = old_inode->i_ino; |
inode | 810 | fs/sysv/namei.c | int sysv_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 811 | fs/sysv/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 23 | fs/sysv/symlink.c | static int sysv_readlink(struct inode *, char *, int); |
inode | 24 | fs/sysv/symlink.c | static int sysv_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 49 | fs/sysv/symlink.c | static int sysv_follow_link(struct inode * dir, struct inode * inode, |
inode | 50 | fs/sysv/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 60 | fs/sysv/symlink.c | if (!inode) { |
inode | 64 | fs/sysv/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 66 | fs/sysv/symlink.c | *res_inode = inode; |
inode | 70 | fs/sysv/symlink.c | iput(inode); |
inode | 74 | fs/sysv/symlink.c | if (!(bh = sysv_file_bread(inode, 0, 0))) { /* is reading 1 block enough ?? */ |
inode | 75 | fs/sysv/symlink.c | iput(inode); |
inode | 79 | fs/sysv/symlink.c | iput(inode); |
inode | 87 | fs/sysv/symlink.c | static int sysv_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 94 | fs/sysv/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 95 | fs/sysv/symlink.c | iput(inode); |
inode | 98 | fs/sysv/symlink.c | if (buflen > inode->i_sb->sv_block_size_1) |
inode | 99 | fs/sysv/symlink.c | buflen = inode->i_sb->sv_block_size_1; |
inode | 100 | fs/sysv/symlink.c | bh = sysv_file_bread(inode, 0, 0); |
inode | 101 | fs/sysv/symlink.c | iput(inode); |
inode | 40 | fs/sysv/truncate.c | static int trunc_direct(struct inode * inode) |
inode | 49 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 51 | fs/sysv/truncate.c | for (i = ((unsigned long) inode->i_size + sb->sv_block_size_1) >> sb->sv_block_size_bits; i < 10; i++) { |
inode | 52 | fs/sysv/truncate.c | p = inode->u.sysv_i.i_data + i; |
inode | 56 | fs/sysv/truncate.c | bh = sv_get_hash_table(sb, inode->i_dev, block); |
inode | 57 | fs/sysv/truncate.c | if ((i << sb->sv_block_size_bits) < inode->i_size) { |
inode | 67 | fs/sysv/truncate.c | inode->i_dirt = 1; |
inode | 74 | fs/sysv/truncate.c | static int trunc_indirect(struct inode * inode, unsigned long offset, unsigned long * p, int convert, unsigned char * dirt) |
inode | 90 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 91 | fs/sysv/truncate.c | indbh = sv_bread(sb, inode->i_dev, indblock); |
inode | 102 | fs/sysv/truncate.c | if (inode->i_size < offset) |
inode | 105 | fs/sysv/truncate.c | i = (inode->i_size - offset + sb->sv_block_size_1) >> sb->sv_block_size_bits; |
inode | 113 | fs/sysv/truncate.c | bh = sv_get_hash_table(sb, inode->i_dev, block); |
inode | 114 | fs/sysv/truncate.c | if ((i << sb->sv_block_size_bits) + offset < inode->i_size) { |
inode | 143 | fs/sysv/truncate.c | static int trunc_dindirect(struct inode * inode, unsigned long offset, unsigned long * p, int convert, unsigned char * dirt) |
inode | 158 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 159 | fs/sysv/truncate.c | indbh = sv_bread(sb, inode->i_dev, indblock); |
inode | 169 | fs/sysv/truncate.c | if (inode->i_size < offset) |
inode | 172 | fs/sysv/truncate.c | i = (inode->i_size - offset + sb->sv_ind_per_block_block_size_1) >> sb->sv_ind_per_block_block_size_bits; |
inode | 181 | fs/sysv/truncate.c | retry |= trunc_indirect(inode,offset+(i<<sb->sv_ind_per_block_bits),ind,sb->sv_convert,&dirty); |
inode | 200 | fs/sysv/truncate.c | static int trunc_tindirect(struct inode * inode, unsigned long offset, unsigned long * p, int convert, unsigned char * dirt) |
inode | 215 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 216 | fs/sysv/truncate.c | indbh = sv_bread(sb, inode->i_dev, indblock); |
inode | 226 | fs/sysv/truncate.c | if (inode->i_size < offset) |
inode | 229 | fs/sysv/truncate.c | i = (inode->i_size - offset + sb->sv_ind_per_block_2_block_size_1) >> sb->sv_ind_per_block_2_block_size_bits; |
inode | 238 | fs/sysv/truncate.c | retry |= trunc_dindirect(inode,offset+(i<<sb->sv_ind_per_block_2_bits),ind,sb->sv_convert,&dirty); |
inode | 257 | fs/sysv/truncate.c | static int trunc_all(struct inode * inode) |
inode | 261 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 262 | fs/sysv/truncate.c | return trunc_direct(inode) |
inode | 263 | fs/sysv/truncate.c | | trunc_indirect(inode,sb->sv_ind0_size,&inode->u.sysv_i.i_data[10],0,&inode->i_dirt) |
inode | 264 | fs/sysv/truncate.c | | trunc_dindirect(inode,sb->sv_ind1_size,&inode->u.sysv_i.i_data[11],0,&inode->i_dirt) |
inode | 265 | fs/sysv/truncate.c | | trunc_tindirect(inode,sb->sv_ind2_size,&inode->u.sysv_i.i_data[12],0,&inode->i_dirt); |
inode | 269 | fs/sysv/truncate.c | void sysv_truncate(struct inode * inode) |
inode | 279 | fs/sysv/truncate.c | if (S_ISLNK(inode->i_mode)) |
inode | 281 | fs/sysv/truncate.c | else if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode))) |
inode | 283 | fs/sysv/truncate.c | while (trunc_all(inode)) { |
inode | 287 | fs/sysv/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 288 | fs/sysv/truncate.c | inode->i_dirt = 1; |
inode | 16 | fs/ufs/ufs_dir.c | extern int ufs_lookup (struct inode *, const char *, int, struct inode **); |
inode | 17 | fs/ufs/ufs_dir.c | extern int ufs_bmap (struct inode *, int); |
inode | 18 | fs/ufs/ufs_dir.c | extern void ufs_print_inode (struct inode *); |
inode | 24 | fs/ufs/ufs_dir.c | ufs_readdir (struct inode * inode, struct file * filp, void * dirent, |
inode | 34 | fs/ufs/ufs_dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 36 | fs/ufs/ufs_dir.c | sb = inode->i_sb; |
inode | 38 | fs/ufs/ufs_dir.c | if (inode->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
inode | 40 | fs/ufs/ufs_dir.c | inode->i_ino, (unsigned long) filp->f_pos); |
inode | 41 | fs/ufs/ufs_dir.c | ufs_print_inode(inode); |
inode | 48 | fs/ufs/ufs_dir.c | while (!error && !stored && filp->f_pos < inode->i_size) { |
inode | 50 | fs/ufs/ufs_dir.c | blk = ufs_bmap(inode, lblk); |
inode | 52 | fs/ufs/ufs_dir.c | blk = ufs_bmap(inode, lblk); |
inode | 57 | fs/ufs/ufs_dir.c | inode->i_ino, (unsigned long int)filp->f_pos); |
inode | 67 | fs/ufs/ufs_dir.c | if (filp->f_version != inode->i_version) { |
inode | 84 | fs/ufs/ufs_dir.c | filp->f_version = inode->i_version; |
inode | 87 | fs/ufs/ufs_dir.c | while (!error && filp->f_pos < inode->i_size |
inode | 97 | fs/ufs/ufs_dir.c | if (!ext2_check_dir_entry ("ext2_readdir", inode, de, |
inode | 116 | fs/ufs/ufs_dir.c | dcache_add(inode, de->d_name, de->d_namlen, |
inode | 118 | fs/ufs/ufs_dir.c | version = inode->i_version; |
inode | 119 | fs/ufs/ufs_dir.c | if (inode->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
inode | 126 | fs/ufs/ufs_dir.c | if (version != inode->i_version) |
inode | 136 | fs/ufs/ufs_dir.c | if (!IS_RDONLY(inode)) { |
inode | 137 | fs/ufs/ufs_dir.c | inode->i_atime = CURRENT_TIME; |
inode | 138 | fs/ufs/ufs_dir.c | inode->i_dirt = 1; |
inode | 20 | fs/ufs/ufs_file.c | int ufs_bmap (struct inode * inode, int block) |
inode | 59 | fs/ufs/ufs_file.c | fsblkno = inode->u.ufs_i.ui_db[lfsblkno]; /* XXX */ |
inode | 61 | fs/ufs/ufs_file.c | phys_block = ufs_cgdmin(inode->i_sb, ufs_ino2cg(inode)) + |
inode | 62 | fs/ufs/ufs_file.c | blkno%(inode->i_sb->u.ufs_sb.s_fpg); |
inode | 65 | fs/ufs/ufs_file.c | if (inode->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
inode | 67 | fs/ufs/ufs_file.c | inode->i_ino, block, fsblkno, phys_block); |
inode | 74 | fs/ufs/ufs_file.c | if (block < (inode->i_sb->s_blocksize/sizeof(__u32))) { |
inode | 75 | fs/ufs/ufs_file.c | bh = bread(inode->i_dev, inode->u.ufs_i.ui_ib[0], |
inode | 79 | fs/ufs/ufs_file.c | block + UFS_NDADDR, inode->i_ino); |
inode | 85 | fs/ufs/ufs_file.c | inode->i_ino, block + UFS_NDADDR, phys_block); |
inode | 89 | fs/ufs/ufs_file.c | inode->i_ino); |
inode | 24 | fs/ufs/ufs_inode.c | void ufs_print_inode(struct inode * inode) |
inode | 27 | fs/ufs/ufs_inode.c | inode->i_ino, inode->i_mode, inode->i_nlink, inode->i_uid, inode->i_gid, inode->i_size, inode->i_blocks, inode->i_count); |
inode | 29 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[0], inode->u.ufs_i.ui_db[1], |
inode | 30 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[2], inode->u.ufs_i.ui_db[3], |
inode | 31 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[4], inode->u.ufs_i.ui_db[5], |
inode | 32 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[6], inode->u.ufs_i.ui_db[7], |
inode | 33 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[8], inode->u.ufs_i.ui_db[9], |
inode | 34 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[10], inode->u.ufs_i.ui_db[11]); |
inode | 36 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_gen, inode->u.ufs_i.ui_ib[0], |
inode | 37 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_ib[1], inode->u.ufs_i.ui_ib[2]); |
inode | 41 | fs/ufs/ufs_inode.c | void ufs_read_inode(struct inode * inode) |
inode | 47 | fs/ufs/ufs_inode.c | sb = inode->i_sb; |
inode | 49 | fs/ufs/ufs_inode.c | if (ufs_ino_ok(inode)) { |
inode | 50 | fs/ufs/ufs_inode.c | printk("ufs_read_inode: bad inum %lu", inode->i_ino); |
inode | 57 | fs/ufs/ufs_inode.c | inode->i_ino, ufs_ino2cg(inode), |
inode | 58 | fs/ufs/ufs_inode.c | (inode->i_ino%sb->u.ufs_sb.s_inopb), |
inode | 61 | fs/ufs/ufs_inode.c | bh = bread(inode->i_dev, |
inode | 62 | fs/ufs/ufs_inode.c | ufs_cgimin(inode->i_sb, ufs_ino2cg(inode)) + |
inode | 63 | fs/ufs/ufs_inode.c | (inode->i_ino%sb->u.ufs_sb.s_ipg)/(sb->u.ufs_sb.s_inopb/sb->u.ufs_sb.s_fsfrag), |
inode | 67 | fs/ufs/ufs_inode.c | inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 72 | fs/ufs/ufs_inode.c | ufsip += (inode->i_ino%(sb->u.ufs_sb.s_inopb/sb->u.ufs_sb.s_fsfrag)); |
inode | 77 | fs/ufs/ufs_inode.c | inode->i_mode = ufsip->ui_mode; |
inode | 78 | fs/ufs/ufs_inode.c | inode->i_nlink = ufsip->ui_nlink; |
inode | 79 | fs/ufs/ufs_inode.c | if (inode->i_nlink == 0) { |
inode | 82 | fs/ufs/ufs_inode.c | inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 83 | fs/ufs/ufs_inode.c | inode->i_nlink = 1; |
inode | 85 | fs/ufs/ufs_inode.c | inode->i_ino, |
inode | 86 | fs/ufs/ufs_inode.c | ufs_cgimin(inode->i_sb, ufs_ino2cg(inode)) + |
inode | 87 | fs/ufs/ufs_inode.c | (inode->i_ino%sb->u.ufs_sb.s_ipg)/sb->u.ufs_sb.s_inopb, |
inode | 88 | fs/ufs/ufs_inode.c | MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 93 | fs/ufs/ufs_inode.c | inode->i_ino, |
inode | 94 | fs/ufs/ufs_inode.c | ufs_cgimin(inode->i_sb, ufs_ino2cg(inode)) + |
inode | 95 | fs/ufs/ufs_inode.c | (inode->i_ino%sb->u.ufs_sb.s_ipg)/sb->u.ufs_sb.s_inopb, |
inode | 96 | fs/ufs/ufs_inode.c | MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 107 | fs/ufs/ufs_inode.c | inode->i_uid = 0; |
inode | 109 | fs/ufs/ufs_inode.c | ufsip->ui_uid, inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev), |
inode | 110 | fs/ufs/ufs_inode.c | inode->i_uid); |
inode | 112 | fs/ufs/ufs_inode.c | inode->i_uid = ufsip->ui_suid; |
inode | 116 | fs/ufs/ufs_inode.c | inode->i_uid = 0; |
inode | 118 | fs/ufs/ufs_inode.c | ufsip->ui_gid, inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev), |
inode | 119 | fs/ufs/ufs_inode.c | inode->i_gid); |
inode | 121 | fs/ufs/ufs_inode.c | inode->i_gid = ufsip->ui_sgid; |
inode | 130 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_size = ((__u64)(ufsip->ui_size.val[0])<<32) | (__u64)(ufsip->ui_size.val[1]); |
inode | 131 | fs/ufs/ufs_inode.c | inode->i_size = ufsip->ui_size.val[1]; /* XXX - endianity */ |
inode | 133 | fs/ufs/ufs_inode.c | inode->i_size = 0xffffffff; |
inode | 135 | fs/ufs/ufs_inode.c | inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 143 | fs/ufs/ufs_inode.c | inode->i_atime = ufsip->ui_atime.tv_sec; |
inode | 144 | fs/ufs/ufs_inode.c | inode->i_mtime = ufsip->ui_mtime.tv_sec; |
inode | 145 | fs/ufs/ufs_inode.c | inode->i_ctime = ufsip->ui_ctime.tv_sec; |
inode | 146 | fs/ufs/ufs_inode.c | inode->i_blksize = sb->u.ufs_sb.s_fsize; |
inode | 147 | fs/ufs/ufs_inode.c | inode->i_blocks = ufsip->ui_blocks; |
inode | 148 | fs/ufs/ufs_inode.c | inode->i_version = ++event; /* see linux/kernel/sched.c */ |
inode | 150 | fs/ufs/ufs_inode.c | if (S_ISREG(inode->i_mode)) { |
inode | 151 | fs/ufs/ufs_inode.c | inode->i_op = &ufs_file_inode_operations; |
inode | 152 | fs/ufs/ufs_inode.c | } else if (S_ISDIR(inode->i_mode)) { |
inode | 153 | fs/ufs/ufs_inode.c | inode->i_op = &ufs_dir_inode_operations; |
inode | 154 | fs/ufs/ufs_inode.c | } else if (S_ISLNK(inode->i_mode)) { |
inode | 155 | fs/ufs/ufs_inode.c | inode->i_op = &ufs_symlink_inode_operations; |
inode | 156 | fs/ufs/ufs_inode.c | } else if (S_ISCHR(inode->i_mode)) { |
inode | 157 | fs/ufs/ufs_inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 158 | fs/ufs/ufs_inode.c | } else if (S_ISBLK(inode->i_mode)) { |
inode | 159 | fs/ufs/ufs_inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 160 | fs/ufs/ufs_inode.c | } else if (S_ISFIFO(inode->i_mode)) { |
inode | 161 | fs/ufs/ufs_inode.c | init_fifo(inode); |
inode | 164 | fs/ufs/ufs_inode.c | inode->i_mode, inode->i_ino, MAJOR(inode->i_dev), |
inode | 165 | fs/ufs/ufs_inode.c | MINOR(inode->i_dev)); |
inode | 167 | fs/ufs/ufs_inode.c | ufs_print_inode(inode); |
inode | 168 | fs/ufs/ufs_inode.c | inode->i_op = &ufs_file_inode_operations; |
inode | 174 | fs/ufs/ufs_inode.c | if (S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 175 | fs/ufs/ufs_inode.c | S_ISLNK(inode->i_mode)) { |
inode | 179 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_db[i] = ufsip->ui_db[i]; |
inode | 182 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_ib[i] = ufsip->ui_ib[i]; |
inode | 186 | fs/ufs/ufs_inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) { |
inode | 188 | fs/ufs/ufs_inode.c | inode->i_rdev = ufsip->ui_db[0]; |
inode | 193 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_flags = ufsip->ui_flags; |
inode | 194 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_gen = ufsip->ui_gen; /* XXX - is this i_version? */ |
inode | 195 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_shadow = ufsip->ui_shadow; /* XXX */ |
inode | 196 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_uid = ufsip->ui_uid; |
inode | 197 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_gid = ufsip->ui_gid; |
inode | 198 | fs/ufs/ufs_inode.c | inode->u.ufs_i.ui_oeftflag = ufsip->ui_oeftflag; |
inode | 202 | fs/ufs/ufs_inode.c | if (inode->i_sb->u.ufs_sb.s_flags & (UFS_DEBUG|UFS_DEBUG_INODE)) { |
inode | 203 | fs/ufs/ufs_inode.c | ufs_print_inode(inode); |
inode | 209 | fs/ufs/ufs_inode.c | void ufs_put_inode (struct inode * inode) |
inode | 211 | fs/ufs/ufs_inode.c | if (inode->i_nlink) |
inode | 215 | fs/ufs/ufs_inode.c | inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 216 | fs/ufs/ufs_inode.c | ufs_print_inode(inode); |
inode | 15 | fs/ufs/ufs_namei.c | extern unsigned int ufs_bmap(struct inode * inode, int block); /* XXX */ |
inode | 37 | fs/ufs/ufs_namei.c | int ufs_lookup (struct inode * dir, const char * name, int len, |
inode | 38 | fs/ufs/ufs_namei.c | struct inode ** result) |
inode | 32 | fs/ufs/ufs_super.c | extern void ufs_read_inode(struct inode * inode); |
inode | 33 | fs/ufs/ufs_super.c | extern void ufs_put_inode(struct inode * inode); |
inode | 18 | fs/ufs/ufs_symlink.c | extern int ufs_bmap (struct inode *, int); |
inode | 21 | fs/ufs/ufs_symlink.c | ufs_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 29 | fs/ufs/ufs_symlink.c | if (inode->i_sb->u.ufs_sb.s_flags & (UFS_DEBUG|UFS_DEBUG_LINKS)) { |
inode | 31 | fs/ufs/ufs_symlink.c | inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 34 | fs/ufs/ufs_symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 35 | fs/ufs/ufs_symlink.c | iput (inode); |
inode | 38 | fs/ufs/ufs_symlink.c | if (buflen > inode->i_sb->s_blocksize - 1) |
inode | 39 | fs/ufs/ufs_symlink.c | buflen = inode->i_sb->s_blocksize - 1; |
inode | 40 | fs/ufs/ufs_symlink.c | if (inode->i_blocks) { |
inode | 42 | fs/ufs/ufs_symlink.c | block = ufs_bmap(inode, 0); |
inode | 43 | fs/ufs/ufs_symlink.c | if (inode->i_sb->u.ufs_sb.s_flags &(UFS_DEBUG|UFS_DEBUG_LINKS)) { |
inode | 45 | fs/ufs/ufs_symlink.c | block, inode->i_ino); |
inode | 47 | fs/ufs/ufs_symlink.c | bh = bread(inode->i_dev, block, BLOCK_SIZE); |
inode | 49 | fs/ufs/ufs_symlink.c | iput (inode); |
inode | 51 | fs/ufs/ufs_symlink.c | inode->i_ino, MAJOR(inode->i_dev), |
inode | 52 | fs/ufs/ufs_symlink.c | MINOR(inode->i_dev)); |
inode | 58 | fs/ufs/ufs_symlink.c | link = (char *)&(inode->u.ufs_i.ui_db[0]); |
inode | 65 | fs/ufs/ufs_symlink.c | iput (inode); |
inode | 75 | fs/ufs/ufs_symlink.c | ufs_follow_link(struct inode * dir, struct inode * inode, |
inode | 76 | fs/ufs/ufs_symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 85 | fs/ufs/ufs_symlink.c | if (inode->i_sb->u.ufs_sb.s_flags & (UFS_DEBUG|UFS_DEBUG_LINKS)) { |
inode | 95 | fs/ufs/ufs_symlink.c | if (!inode) { |
inode | 99 | fs/ufs/ufs_symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 101 | fs/ufs/ufs_symlink.c | *res_inode = inode; |
inode | 106 | fs/ufs/ufs_symlink.c | iput (inode); |
inode | 109 | fs/ufs/ufs_symlink.c | if (inode->i_blocks) { |
inode | 112 | fs/ufs/ufs_symlink.c | block = ufs_bmap(inode, 0); |
inode | 113 | fs/ufs/ufs_symlink.c | bh = bread(inode->i_dev, block, BLOCK_SIZE); |
inode | 116 | fs/ufs/ufs_symlink.c | inode->i_ino, MAJOR(inode->i_dev), |
inode | 117 | fs/ufs/ufs_symlink.c | MINOR(inode->i_dev)); |
inode | 119 | fs/ufs/ufs_symlink.c | iput(inode); |
inode | 125 | fs/ufs/ufs_symlink.c | link = (char *)&(inode->u.ufs_i.ui_db[0]); |
inode | 130 | fs/ufs/ufs_symlink.c | iput (inode); |
inode | 26 | fs/umsdos/dir.c | extern struct inode *pseudo_root; |
inode | 30 | fs/umsdos/dir.c | int UMSDOS_dir_read(struct inode *inode,struct file *filp,char *buf, |
inode | 80 | fs/umsdos/dir.c | struct inode *dir, /* Point to a description of the super block */ |
inode | 159 | fs/umsdos/dir.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,0); |
inode | 191 | fs/umsdos/dir.c | struct inode *inode; |
inode | 197 | fs/umsdos/dir.c | ,info.fake.len,&inode); |
inode | 203 | fs/umsdos/dir.c | struct inode *rinode; |
inode | 204 | fs/umsdos/dir.c | lret = umsdos_hlink2inode (inode,&rinode); |
inode | 205 | fs/umsdos/dir.c | inode = rinode; |
inode | 215 | fs/umsdos/dir.c | if (inode != pseudo_root |
inode | 220 | fs/umsdos/dir.c | ,cur_f_pos, inode->i_ino) < 0){ |
inode | 223 | fs/umsdos/dir.c | PRINTK (("Trouve ino %ld ",inode->i_ino)); |
inode | 225 | fs/umsdos/dir.c | iput (inode); |
inode | 228 | fs/umsdos/dir.c | iput (inode); |
inode | 262 | fs/umsdos/dir.c | struct inode *dir, /* Point to a description of the super block */ |
inode | 289 | fs/umsdos/dir.c | struct inode *dir, |
inode | 290 | fs/umsdos/dir.c | struct inode *inode, |
inode | 323 | fs/umsdos/dir.c | if (inode->i_sb == dir->i_sb && !umsdos_isinit(inode)){ |
inode | 324 | fs/umsdos/dir.c | if (S_ISDIR(inode->i_mode)) umsdos_lockcreate(inode); |
inode | 325 | fs/umsdos/dir.c | if (!umsdos_isinit(inode)){ |
inode | 343 | fs/umsdos/dir.c | if (S_ISREG(entry->mode)) entry->mtime = inode->i_mtime; |
inode | 344 | fs/umsdos/dir.c | inode->i_mode = entry->mode; |
inode | 345 | fs/umsdos/dir.c | inode->i_rdev = to_kdev_t(entry->rdev); |
inode | 346 | fs/umsdos/dir.c | inode->i_atime = entry->atime; |
inode | 347 | fs/umsdos/dir.c | inode->i_ctime = entry->ctime; |
inode | 348 | fs/umsdos/dir.c | inode->i_mtime = entry->mtime; |
inode | 349 | fs/umsdos/dir.c | inode->i_uid = entry->uid; |
inode | 350 | fs/umsdos/dir.c | inode->i_gid = entry->gid; |
inode | 386 | fs/umsdos/dir.c | MSDOS_I(inode)->i_binary = 1; |
inode | 397 | fs/umsdos/dir.c | inode->i_nlink = entry->nlink; |
inode | 402 | fs/umsdos/dir.c | umsdos_patch_inode(inode,dir,emd_pos); |
inode | 404 | fs/umsdos/dir.c | if (S_ISDIR(inode->i_mode)) umsdos_unlockcreate(inode); |
inode | 405 | fs/umsdos/dir.c | if (inode->u.umsdos_i.i_emd_owner==0) printk ("emd_owner still 0 ???\n"); |
inode | 463 | fs/umsdos/dir.c | struct inode *dir, |
inode | 464 | fs/umsdos/dir.c | struct inode *inode, |
inode | 468 | fs/umsdos/dir.c | if (inode == pseudo_root){ |
inode | 477 | fs/umsdos/dir.c | struct inode *emddir = umsdos_emd_dir_lookup(dir,0); |
inode | 486 | fs/umsdos/dir.c | bufk.search_ino = inode->i_ino; |
inode | 490 | fs/umsdos/dir.c | inode->u.umsdos_i.i_dir_owner = dir->i_ino; |
inode | 491 | fs/umsdos/dir.c | inode->u.umsdos_i.i_emd_owner = 0; |
inode | 492 | fs/umsdos/dir.c | umsdos_setup_dir_inode(inode); |
inode | 504 | fs/umsdos/dir.c | ,inode->i_ino); |
inode | 506 | fs/umsdos/dir.c | }else if (bufk.ino == inode->i_ino){ |
inode | 508 | fs/umsdos/dir.c | umsdos_lookup_patch (dir,inode,entry,bufk.f_pos); |
inode | 521 | fs/umsdos/dir.c | struct inode *dir, |
inode | 522 | fs/umsdos/dir.c | struct inode **result, |
inode | 530 | fs/umsdos/dir.c | struct inode *adir = *result; |
inode | 543 | fs/umsdos/dir.c | struct inode *inode, |
inode | 547 | fs/umsdos/dir.c | struct inode *dir = inode; |
inode | 555 | fs/umsdos/dir.c | PRINTK (("locate_path mode %x ",inode->i_mode)); |
inode | 556 | fs/umsdos/dir.c | if (!S_ISDIR(inode->i_mode)){ |
inode | 557 | fs/umsdos/dir.c | ret = umsdos_get_dirowner (inode,&dir); |
inode | 560 | fs/umsdos/dir.c | ret = umsdos_inode2entry (dir,inode,&entry); |
inode | 572 | fs/umsdos/dir.c | struct inode *adir; |
inode | 600 | fs/umsdos/dir.c | struct inode *dir, |
inode | 620 | fs/umsdos/dir.c | struct inode *dir, |
inode | 623 | fs/umsdos/dir.c | struct inode **result, /* Will hold inode of the file, if successful */ |
inode | 659 | fs/umsdos/dir.c | struct inode *aadir; |
inode | 689 | fs/umsdos/dir.c | struct inode *inode; |
inode | 691 | fs/umsdos/dir.c | inode = *result; |
inode | 692 | fs/umsdos/dir.c | if (inode == NULL){ |
inode | 697 | fs/umsdos/dir.c | umsdos_lookup_patch (dir,inode,&info.entry,info.f_pos); |
inode | 698 | fs/umsdos/dir.c | PRINTK (("lookup ino %ld flags %d\n",inode->i_ino |
inode | 701 | fs/umsdos/dir.c | ret = umsdos_hlink2inode (inode,result); |
inode | 729 | fs/umsdos/dir.c | struct inode *dir, |
inode | 732 | fs/umsdos/dir.c | struct inode **result) /* Will hold inode of the file, if successful */ |
inode | 740 | fs/umsdos/dir.c | int umsdos_hlink2inode (struct inode *hlink, struct inode **result) |
inode | 755 | fs/umsdos/dir.c | struct inode *dir; |
inode | 27 | fs/umsdos/emd.c | struct inode *inode, |
inode | 35 | fs/umsdos/emd.c | ret = fat_file_read(inode,filp,buf,count); |
inode | 43 | fs/umsdos/emd.c | struct inode *inode, |
inode | 51 | fs/umsdos/emd.c | ret = fat_file_write(inode,filp,buf,count); |
inode | 64 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 80 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 102 | fs/umsdos/emd.c | struct inode *umsdos_emd_dir_lookup(struct inode *dir, int creat) |
inode | 104 | fs/umsdos/emd.c | struct inode *ret = NULL; |
inode | 142 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 163 | fs/umsdos/emd.c | struct inode *dir, |
inode | 164 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 219 | fs/umsdos/emd.c | struct inode *inode, |
inode | 231 | fs/umsdos/emd.c | remain = inode->i_size - buf->filp.f_pos; |
inode | 234 | fs/umsdos/emd.c | ret = umsdos_emd_dir_read (inode,&buf->filp,buf->buffer+mustmove |
inode | 266 | fs/umsdos/emd.c | struct inode *dir, |
inode | 269 | fs/umsdos/emd.c | struct inode **pt_emd_dir) /* Will hold the emd_dir inode */ |
inode | 278 | fs/umsdos/emd.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,1); |
inode | 366 | fs/umsdos/emd.c | struct inode *dir, |
inode | 369 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 385 | fs/umsdos/emd.c | struct inode *dir, |
inode | 388 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 413 | fs/umsdos/emd.c | struct inode *dir, |
inode | 417 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 443 | fs/umsdos/emd.c | int umsdos_isempty (struct inode *dir) |
inode | 446 | fs/umsdos/emd.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,0); |
inode | 475 | fs/umsdos/emd.c | struct inode *dir, |
inode | 481 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 28 | fs/umsdos/file.c | struct inode *inode, |
inode | 34 | fs/umsdos/file.c | int ret = fat_file_read(inode,filp,buf,count); |
inode | 35 | fs/umsdos/file.c | if (!IS_RDONLY(inode)){ |
inode | 36 | fs/umsdos/file.c | inode->i_atime = CURRENT_TIME; |
inode | 37 | fs/umsdos/file.c | inode->i_dirt = 1; |
inode | 45 | fs/umsdos/file.c | struct inode *inode, |
inode | 50 | fs/umsdos/file.c | return fat_file_write(inode,filp,buf,count); |
inode | 55 | fs/umsdos/file.c | static void UMSDOS_truncate(struct inode *inode) |
inode | 58 | fs/umsdos/file.c | fat_truncate (inode); |
inode | 59 | fs/umsdos/file.c | inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 60 | fs/umsdos/file.c | inode->i_dirt = 1; |
inode | 21 | fs/umsdos/inode.c | struct inode *pseudo_root=NULL; /* Useful to simulate the pseudo DOS */ |
inode | 39 | fs/umsdos/inode.c | void UMSDOS_put_inode(struct inode *inode) |
inode | 41 | fs/umsdos/inode.c | PRINTK (("put inode %x owner %x pos %d dir %x\n",inode |
inode | 42 | fs/umsdos/inode.c | ,inode->u.umsdos_i.i_emd_owner,inode->u.umsdos_i.pos |
inode | 43 | fs/umsdos/inode.c | ,inode->u.umsdos_i.i_emd_dir)); |
inode | 44 | fs/umsdos/inode.c | if (inode != NULL && inode == pseudo_root){ |
inode | 47 | fs/umsdos/inode.c | fat_put_inode(inode); |
inode | 69 | fs/umsdos/inode.c | struct inode *dir, |
inode | 72 | fs/umsdos/inode.c | struct inode **result) /* Will hold inode of the file, if successful */ |
inode | 85 | fs/umsdos/inode.c | void umsdos_setup_dir_inode (struct inode *inode) |
inode | 87 | fs/umsdos/inode.c | inode->u.umsdos_i.i_emd_dir = 0; |
inode | 89 | fs/umsdos/inode.c | struct inode *emd_dir = umsdos_emd_dir_lookup (inode,0); |
inode | 91 | fs/umsdos/inode.c | inode->i_op = emd_dir != NULL |
inode | 101 | fs/umsdos/inode.c | struct inode *inode, |
inode | 102 | fs/umsdos/inode.c | struct inode *dir, |
inode | 105 | fs/umsdos/inode.c | struct inode *emd_owner = umsdos_emd_dir_lookup(dir,1); |
inode | 106 | fs/umsdos/inode.c | inode->u.umsdos_i.i_dir_owner = dir->i_ino; |
inode | 107 | fs/umsdos/inode.c | inode->u.umsdos_i.i_emd_owner = emd_owner->i_ino; |
inode | 109 | fs/umsdos/inode.c | inode->u.umsdos_i.pos = f_pos; |
inode | 115 | fs/umsdos/inode.c | int umsdos_isinit (struct inode *inode) |
inode | 118 | fs/umsdos/inode.c | return inode->u.umsdos_i.i_emd_owner != 0; |
inode | 120 | fs/umsdos/inode.c | return inode->i_atime != 0; |
inode | 122 | fs/umsdos/inode.c | return inode->i_count > 1; |
inode | 129 | fs/umsdos/inode.c | struct inode *inode, |
inode | 130 | fs/umsdos/inode.c | struct inode *dir, /* May be NULL */ |
inode | 149 | fs/umsdos/inode.c | if (!umsdos_isinit(inode)){ |
inode | 150 | fs/umsdos/inode.c | inode->u.umsdos_i.i_emd_dir = 0; |
inode | 151 | fs/umsdos/inode.c | if (S_ISREG(inode->i_mode)){ |
inode | 152 | fs/umsdos/inode.c | if (inode->i_op->bmap != NULL){ |
inode | 153 | fs/umsdos/inode.c | inode->i_op = &umsdos_file_inode_operations; |
inode | 155 | fs/umsdos/inode.c | inode->i_op = &umsdos_file_inode_operations_no_bmap; |
inode | 157 | fs/umsdos/inode.c | }else if (S_ISDIR(inode->i_mode)){ |
inode | 159 | fs/umsdos/inode.c | umsdos_setup_dir_inode(inode); |
inode | 161 | fs/umsdos/inode.c | }else if (S_ISLNK(inode->i_mode)){ |
inode | 162 | fs/umsdos/inode.c | inode->i_op = &umsdos_symlink_inode_operations; |
inode | 163 | fs/umsdos/inode.c | }else if (S_ISCHR(inode->i_mode)){ |
inode | 164 | fs/umsdos/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 165 | fs/umsdos/inode.c | }else if (S_ISBLK(inode->i_mode)){ |
inode | 166 | fs/umsdos/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 167 | fs/umsdos/inode.c | }else if (S_ISFIFO(inode->i_mode)){ |
inode | 168 | fs/umsdos/inode.c | init_fifo(inode); |
inode | 181 | fs/umsdos/inode.c | umsdos_set_dirinfo (inode,dir,f_pos); |
inode | 188 | fs/umsdos/inode.c | struct inode *emd_owner = umsdos_emd_dir_lookup(dir,1); |
inode | 190 | fs/umsdos/inode.c | if (emd_owner->i_ino != inode->u.umsdos_i.i_emd_owner){ |
inode | 192 | fs/umsdos/inode.c | ,inode->i_ino,emd_owner->i_ino,inode->u.umsdos_i.i_emd_owner); |
inode | 201 | fs/umsdos/inode.c | struct inode *inode, |
inode | 202 | fs/umsdos/inode.c | struct inode **result) /* Hold NULL if any error */ |
inode | 206 | fs/umsdos/inode.c | unsigned long ino = inode->u.umsdos_i.i_dir_owner; |
inode | 211 | fs/umsdos/inode.c | struct inode *dir = *result = iget(inode->i_sb,ino); |
inode | 222 | fs/umsdos/inode.c | void UMSDOS_read_inode(struct inode *inode) |
inode | 224 | fs/umsdos/inode.c | PRINTK (("read inode %x ino = %d ",inode,inode->i_ino)); |
inode | 225 | fs/umsdos/inode.c | msdos_read_inode(inode); |
inode | 226 | fs/umsdos/inode.c | PRINTK (("ino = %d %d\n",inode->i_ino,inode->i_count)); |
inode | 227 | fs/umsdos/inode.c | if (S_ISDIR(inode->i_mode) |
inode | 228 | fs/umsdos/inode.c | && (inode->u.umsdos_i.u.dir_info.creating != 0 |
inode | 229 | fs/umsdos/inode.c | || inode->u.umsdos_i.u.dir_info.looking != 0 |
inode | 230 | fs/umsdos/inode.c | || inode->u.umsdos_i.u.dir_info.p != NULL)){ |
inode | 232 | fs/umsdos/inode.c | ,inode->u.umsdos_i.u.dir_info.creating |
inode | 233 | fs/umsdos/inode.c | ,inode->u.umsdos_i.u.dir_info.looking |
inode | 234 | fs/umsdos/inode.c | ,inode->u.umsdos_i.u.dir_info.p)); |
inode | 249 | fs/umsdos/inode.c | umsdos_patch_inode(inode,NULL,0); |
inode | 255 | fs/umsdos/inode.c | void UMSDOS_write_inode(struct inode *inode) |
inode | 259 | fs/umsdos/inode.c | PRINTK (("UMSDOS_write_inode emd %d\n",inode->u.umsdos_i.i_emd_owner)); |
inode | 260 | fs/umsdos/inode.c | fat_write_inode(inode); |
inode | 261 | fs/umsdos/inode.c | newattrs.ia_mtime = inode->i_mtime; |
inode | 262 | fs/umsdos/inode.c | newattrs.ia_atime = inode->i_atime; |
inode | 263 | fs/umsdos/inode.c | newattrs.ia_ctime = inode->i_ctime; |
inode | 270 | fs/umsdos/inode.c | UMSDOS_notify_change (inode, &newattrs); |
inode | 271 | fs/umsdos/inode.c | inode->i_dirt = 0; |
inode | 274 | fs/umsdos/inode.c | int UMSDOS_notify_change(struct inode *inode, struct iattr *attr) |
inode | 278 | fs/umsdos/inode.c | if ((ret = inode_change_ok(inode, attr)) != 0) |
inode | 281 | fs/umsdos/inode.c | if (inode->i_nlink > 0){ |
inode | 287 | fs/umsdos/inode.c | unsigned long i_emd_owner = inode->u.umsdos_i.i_emd_owner; |
inode | 288 | fs/umsdos/inode.c | if (inode == inode->i_sb->s_mounted){ |
inode | 308 | fs/umsdos/inode.c | struct inode *emd_owner = iget (inode->i_sb,i_emd_owner); |
inode | 309 | fs/umsdos/inode.c | PRINTK (("notify change %p ",inode)); |
inode | 316 | fs/umsdos/inode.c | filp.f_pos = inode->u.umsdos_i.pos; |
inode | 337 | fs/umsdos/inode.c | entry.nlink = inode->i_nlink; |
inode | 338 | fs/umsdos/inode.c | filp.f_pos = inode->u.umsdos_i.pos; |
inode | 343 | fs/umsdos/inode.c | ,inode->u.umsdos_i.pos |
inode | 356 | fs/umsdos/inode.c | inode_setattr(inode, attr); |
inode | 444 | fs/umsdos/inode.c | struct inode *pseudo; |
inode | 449 | fs/umsdos/inode.c | struct inode *etc = NULL; |
inode | 450 | fs/umsdos/inode.c | struct inode *sbin = NULL; |
inode | 455 | fs/umsdos/inode.c | struct inode *init = NULL; |
inode | 456 | fs/umsdos/inode.c | struct inode *rc = NULL; |
inode | 470 | fs/umsdos/inode.c | struct inode *init = NULL; |
inode | 56 | fs/umsdos/ioctl.c | struct inode *dir, |
inode | 137 | fs/umsdos/ioctl.c | struct inode *emd_dir = umsdos_emd_dir_lookup (dir,0); |
inode | 181 | fs/umsdos/ioctl.c | struct inode *emd_dir = umsdos_emd_dir_lookup (dir,1); |
inode | 274 | fs/umsdos/ioctl.c | struct inode *inode; |
inode | 276 | fs/umsdos/ioctl.c | ,data.dos_dirent.d_reclen,&inode); |
inode | 278 | fs/umsdos/ioctl.c | data.stat.st_ino = inode->i_ino; |
inode | 279 | fs/umsdos/ioctl.c | data.stat.st_mode = inode->i_mode; |
inode | 280 | fs/umsdos/ioctl.c | data.stat.st_size = inode->i_size; |
inode | 281 | fs/umsdos/ioctl.c | data.stat.st_atime = inode->i_atime; |
inode | 282 | fs/umsdos/ioctl.c | data.stat.st_ctime = inode->i_ctime; |
inode | 283 | fs/umsdos/ioctl.c | data.stat.st_mtime = inode->i_mtime; |
inode | 285 | fs/umsdos/ioctl.c | iput (inode); |
inode | 32 | fs/umsdos/namei.c | static int umsdos_waitcreate(struct inode *dir) |
inode | 45 | fs/umsdos/namei.c | static void umsdos_waitlookup (struct inode *dir) |
inode | 54 | fs/umsdos/namei.c | void umsdos_lockcreate (struct inode *dir) |
inode | 96 | fs/umsdos/namei.c | static void umsdos_lockcreate2 (struct inode *dir1, struct inode *dir2) |
inode | 121 | fs/umsdos/namei.c | void umsdos_startlookup (struct inode *dir) |
inode | 130 | fs/umsdos/namei.c | void umsdos_unlockcreate (struct inode *dir) |
inode | 142 | fs/umsdos/namei.c | void umsdos_endlookup (struct inode *dir) |
inode | 152 | fs/umsdos/namei.c | static void umsdos_lockcreate (struct inode *dir){} |
inode | 153 | fs/umsdos/namei.c | static void umsdos_lockcreate2 (struct inode *dir1, struct inode *dir2){} |
inode | 154 | fs/umsdos/namei.c | void umsdos_startlookup (struct inode *dir){} |
inode | 155 | fs/umsdos/namei.c | static void umsdos_unlockcreate (struct inode *dir){} |
inode | 156 | fs/umsdos/namei.c | void umsdos_endlookup (struct inode *dir){} |
inode | 159 | fs/umsdos/namei.c | struct inode *dir, |
inode | 200 | fs/umsdos/namei.c | struct inode *dir, |
inode | 207 | fs/umsdos/namei.c | struct inode **result) /* Will hold the inode of the newly created */ |
inode | 232 | fs/umsdos/namei.c | struct inode *inode = *result; |
inode | 233 | fs/umsdos/namei.c | umsdos_lookup_patch (dir,inode,&info.entry,info.f_pos); |
inode | 234 | fs/umsdos/namei.c | PRINTK (("inode %p[%d] ",inode,inode->i_count)); |
inode | 309 | fs/umsdos/namei.c | struct inode * old_dir, |
inode | 312 | fs/umsdos/namei.c | struct inode * new_dir, |
inode | 376 | fs/umsdos/namei.c | struct inode *inode; |
inode | 380 | fs/umsdos/namei.c | ,&inode); |
inode | 390 | fs/umsdos/namei.c | umsdos_set_dirinfo (inode,new_dir,new_info.f_pos); |
inode | 392 | fs/umsdos/namei.c | iput (inode); |
inode | 421 | fs/umsdos/namei.c | struct inode * dir, |
inode | 438 | fs/umsdos/namei.c | struct inode *inode; |
inode | 442 | fs/umsdos/namei.c | ret = umsdos_create_any (dir,name,len,mode,0,flags,&inode); |
inode | 449 | fs/umsdos/namei.c | ret = umsdos_file_write_kmem (inode,&filp,symname,len); |
inode | 450 | fs/umsdos/namei.c | iput (inode); |
inode | 474 | fs/umsdos/namei.c | struct inode * dir, |
inode | 485 | fs/umsdos/namei.c | struct inode * oldinode, |
inode | 486 | fs/umsdos/namei.c | struct inode * dir, |
inode | 568 | fs/umsdos/namei.c | struct inode *olddir; |
inode | 665 | fs/umsdos/namei.c | struct inode *dir, |
inode | 669 | fs/umsdos/namei.c | struct inode **result) /* Will hold the inode of the newly created */ |
inode | 678 | fs/umsdos/namei.c | struct inode * dir, |
inode | 717 | fs/umsdos/namei.c | struct inode *subdir; |
inode | 721 | fs/umsdos/namei.c | struct inode *result; |
inode | 744 | fs/umsdos/namei.c | struct inode * dir, |
inode | 764 | fs/umsdos/namei.c | struct inode *inode; |
inode | 765 | fs/umsdos/namei.c | int ret = umsdos_create_any (dir,name,len,mode,rdev,0,&inode); |
inode | 766 | fs/umsdos/namei.c | iput (inode); |
inode | 774 | fs/umsdos/namei.c | struct inode * dir, |
inode | 867 | fs/umsdos/namei.c | struct inode *sdir; |
inode | 928 | fs/umsdos/namei.c | struct inode * dir, |
inode | 958 | fs/umsdos/namei.c | struct inode *inode; |
inode | 960 | fs/umsdos/namei.c | ret = UMSDOS_lookup (dir,name,len,&inode); |
inode | 962 | fs/umsdos/namei.c | PRINTK (("unlink nlink = %d ",inode->i_nlink)); |
inode | 963 | fs/umsdos/namei.c | inode->i_nlink--; |
inode | 964 | fs/umsdos/namei.c | if (inode->i_nlink == 0){ |
inode | 965 | fs/umsdos/namei.c | struct inode *hdir = iget(inode->i_sb |
inode | 966 | fs/umsdos/namei.c | ,inode->u.umsdos_i.i_dir_owner); |
inode | 968 | fs/umsdos/namei.c | ret = umsdos_inode2entry (hdir,inode,&entry); |
inode | 978 | fs/umsdos/namei.c | ret = UMSDOS_notify_change (inode, &newattrs); |
inode | 980 | fs/umsdos/namei.c | iput (inode); |
inode | 1012 | fs/umsdos/namei.c | struct inode * old_dir, |
inode | 1015 | fs/umsdos/namei.c | struct inode * new_dir, |
inode | 25 | fs/umsdos/rdir.c | extern struct inode *pseudo_root; |
inode | 64 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 84 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 87 | fs/umsdos/rdir.c | struct inode **result, /* Will hold inode of the file, if successful */ |
inode | 108 | fs/umsdos/rdir.c | struct inode *inode = *result; |
inode | 109 | fs/umsdos/rdir.c | if (inode == pseudo_root && !nopseudo){ |
inode | 117 | fs/umsdos/rdir.c | }else if (S_ISDIR(inode->i_mode)){ |
inode | 120 | fs/umsdos/rdir.c | umsdos_setup_dir_inode(inode); |
inode | 128 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 131 | fs/umsdos/rdir.c | struct inode **result) /* Will hold inode of the file, if successful */ |
inode | 137 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 171 | fs/umsdos/rdir.c | struct inode *sdir; |
inode | 30 | fs/umsdos/symlink.c | struct inode *inode, |
inode | 32 | fs/umsdos/symlink.c | int (*msdos_read)(struct inode *, struct file *, char *, int), |
inode | 35 | fs/umsdos/symlink.c | int ret = inode->i_size; |
inode | 40 | fs/umsdos/symlink.c | if ((*msdos_read) (inode, &filp, buffer,ret) != ret){ |
inode | 52 | fs/umsdos/symlink.c | struct inode * dir, |
inode | 53 | fs/umsdos/symlink.c | struct inode * inode, |
inode | 56 | fs/umsdos/symlink.c | struct inode ** res_inode) |
inode | 69 | fs/umsdos/symlink.c | if (!inode){ |
inode | 72 | fs/umsdos/symlink.c | }else if (!S_ISLNK(inode->i_mode)){ |
inode | 74 | fs/umsdos/symlink.c | *res_inode = inode; |
inode | 75 | fs/umsdos/symlink.c | inode = NULL; |
inode | 78 | fs/umsdos/symlink.c | ret = umsdos_readlink_x (inode,path |
inode | 83 | fs/umsdos/symlink.c | iput(inode); |
inode | 84 | fs/umsdos/symlink.c | inode = NULL; |
inode | 96 | fs/umsdos/symlink.c | iput(inode); |
inode | 102 | fs/umsdos/symlink.c | static int UMSDOS_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 105 | fs/umsdos/symlink.c | if (S_ISLNK(inode->i_mode)) { |
inode | 106 | fs/umsdos/symlink.c | ret = umsdos_readlink_x (inode,buffer,fat_file_read,buflen); |
inode | 108 | fs/umsdos/symlink.c | PRINTK (("readlink %d %x bufsiz %d\n",ret,inode->i_mode,buflen)); |
inode | 109 | fs/umsdos/symlink.c | iput(inode); |
inode | 59 | fs/vfat/namei.c | void vfat_read_inode(struct inode *inode); |
inode | 226 | fs/vfat/namei.c | static int vfat_find(struct inode *dir,const char *name,int len, |
inode | 394 | fs/vfat/namei.c | static int vfat_create_shortname(struct inode *dir, const char *name, |
inode | 542 | fs/vfat/namei.c | static loff_t vfat_find_free_slots(struct inode *dir,int slots) |
inode | 548 | fs/vfat/namei.c | struct inode *inode; |
inode | 565 | fs/vfat/namei.c | inode = iget(sb,ino); |
inode | 566 | fs/vfat/namei.c | if (inode) { |
inode | 568 | fs/vfat/namei.c | done = !MSDOS_I(inode)->i_busy; |
inode | 571 | fs/vfat/namei.c | iput(inode); |
inode | 714 | fs/vfat/namei.c | static int vfat_build_slots(struct inode *dir,const char *name,int len, |
inode | 802 | fs/vfat/namei.c | static int vfat_find(struct inode *dir,const char *name,int len, |
inode | 909 | fs/vfat/namei.c | int vfat_lookup(struct inode *dir,const char *name,int len, |
inode | 910 | fs/vfat/namei.c | struct inode **result) |
inode | 913 | fs/vfat/namei.c | struct inode *next; |
inode | 979 | fs/vfat/namei.c | static int vfat_create_entry(struct inode *dir,const char *name,int len, |
inode | 980 | fs/vfat/namei.c | int is_dir, struct inode **result) |
inode | 1021 | fs/vfat/namei.c | int vfat_create(struct inode *dir,const char *name,int len,int mode, |
inode | 1022 | fs/vfat/namei.c | struct inode **result) |
inode | 1037 | fs/vfat/namei.c | static int vfat_create_a_dotdir(struct inode *dir,struct inode *parent, |
inode | 1042 | fs/vfat/namei.c | struct inode *dot; |
inode | 1083 | fs/vfat/namei.c | static int vfat_create_dotdirs(struct inode *dir, struct inode *parent) |
inode | 1122 | fs/vfat/namei.c | static int vfat_empty(struct inode *dir) |
inode | 1151 | fs/vfat/namei.c | static int vfat_rmdir_free_ino(struct inode *dir,struct buffer_head *bh, |
inode | 1155 | fs/vfat/namei.c | struct inode *inode; |
inode | 1159 | fs/vfat/namei.c | if (!(inode = iget(dir->i_sb,ino))) return -ENOENT; |
inode | 1160 | fs/vfat/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 1161 | fs/vfat/namei.c | iput(inode); |
inode | 1164 | fs/vfat/namei.c | if (dir->i_dev != inode->i_dev || dir == inode) { |
inode | 1165 | fs/vfat/namei.c | iput(inode); |
inode | 1168 | fs/vfat/namei.c | res = vfat_empty(inode); |
inode | 1170 | fs/vfat/namei.c | iput(inode); |
inode | 1173 | fs/vfat/namei.c | inode->i_nlink = 0; |
inode | 1174 | fs/vfat/namei.c | inode->i_mtime = dir->i_mtime = CURRENT_TIME; |
inode | 1175 | fs/vfat/namei.c | inode->i_atime = dir->i_atime = CURRENT_TIME; |
inode | 1177 | fs/vfat/namei.c | inode->i_dirt = dir->i_dirt = 1; |
inode | 1180 | fs/vfat/namei.c | iput(inode); |
inode | 1185 | fs/vfat/namei.c | static int vfat_unlink_free_ino(struct inode *dir,struct buffer_head *bh, |
inode | 1189 | fs/vfat/namei.c | struct inode *inode; |
inode | 1190 | fs/vfat/namei.c | if (!(inode = iget(dir->i_sb,ino))) return -ENOENT; |
inode | 1191 | fs/vfat/namei.c | if ((!S_ISREG(inode->i_mode) && nospc) || IS_IMMUTABLE(inode)) { |
inode | 1192 | fs/vfat/namei.c | iput(inode); |
inode | 1195 | fs/vfat/namei.c | inode->i_nlink = 0; |
inode | 1196 | fs/vfat/namei.c | inode->i_mtime = dir->i_mtime = CURRENT_TIME; |
inode | 1197 | fs/vfat/namei.c | inode->i_atime = dir->i_atime = CURRENT_TIME; |
inode | 1199 | fs/vfat/namei.c | MSDOS_I(inode)->i_busy = 1; |
inode | 1200 | fs/vfat/namei.c | inode->i_dirt = dir->i_dirt = 1; |
inode | 1204 | fs/vfat/namei.c | iput(inode); |
inode | 1208 | fs/vfat/namei.c | static int vfat_remove_entry(struct inode *dir,struct slot_info *sinfo, |
inode | 1243 | fs/vfat/namei.c | static int vfat_rmdirx(struct inode *dir,const char *name,int len) |
inode | 1273 | fs/vfat/namei.c | int vfat_rmdir(struct inode *dir,const char *name,int len) |
inode | 1283 | fs/vfat/namei.c | struct inode *dir, |
inode | 1313 | fs/vfat/namei.c | int vfat_mkdir(struct inode *dir,const char *name,int len,int mode) |
inode | 1315 | fs/vfat/namei.c | struct inode *inode; |
inode | 1319 | fs/vfat/namei.c | if ((res = vfat_create_entry(dir,name,len,1,&inode)) < 0) { |
inode | 1326 | fs/vfat/namei.c | inode->i_nlink = 2; /* no need to mark them dirty */ |
inode | 1327 | fs/vfat/namei.c | MSDOS_I(inode)->i_busy = 1; /* prevent lookups */ |
inode | 1329 | fs/vfat/namei.c | res = vfat_create_dotdirs(inode, dir); |
inode | 1331 | fs/vfat/namei.c | MSDOS_I(inode)->i_busy = 0; |
inode | 1332 | fs/vfat/namei.c | iput(inode); |
inode | 1342 | fs/vfat/namei.c | int vfat_unlink(struct inode *dir,const char *name,int len) |
inode | 1352 | fs/vfat/namei.c | int vfat_rename(struct inode *old_dir,const char *old_name,int old_len, |
inode | 1353 | fs/vfat/namei.c | struct inode *new_dir,const char *new_name,int new_len) |
inode | 1360 | fs/vfat/namei.c | struct inode *old_inode, *new_inode, *dotdot_inode, *walk; |
inode | 1560 | fs/vfat/namei.c | void vfat_read_inode(struct inode *inode) |
inode | 1562 | fs/vfat/namei.c | fat_read_inode(inode, &vfat_dir_inode_operations); |
inode | 278 | fs/xiafs/bitmap.c | void xiafs_free_inode(struct inode * inode) |
inode | 284 | fs/xiafs/bitmap.c | if (!inode) |
inode | 286 | fs/xiafs/bitmap.c | if (!inode->i_dev || inode->i_count!=1 |
inode | 287 | fs/xiafs/bitmap.c | || inode->i_nlink || !inode->i_sb || inode->i_ino < 3 |
inode | 288 | fs/xiafs/bitmap.c | || inode->i_ino > inode->i_sb->u.xiafs_sb.s_ninodes) { |
inode | 292 | fs/xiafs/bitmap.c | sb = inode->i_sb; |
inode | 293 | fs/xiafs/bitmap.c | ino = inode->i_ino; |
inode | 297 | fs/xiafs/bitmap.c | clear_inode(inode); |
inode | 301 | fs/xiafs/bitmap.c | kdevname(inode->i_dev), ino, ino, WHERE_ERR); |
inode | 306 | fs/xiafs/bitmap.c | struct inode * xiafs_new_inode(struct inode * dir) |
inode | 309 | fs/xiafs/bitmap.c | struct inode * inode; |
inode | 313 | fs/xiafs/bitmap.c | if (!dir || !(inode = get_empty_inode())) |
inode | 315 | fs/xiafs/bitmap.c | inode->i_sb = sb; |
inode | 316 | fs/xiafs/bitmap.c | inode->i_flags = inode->i_sb->s_flags; |
inode | 320 | fs/xiafs/bitmap.c | iput(inode); |
inode | 323 | fs/xiafs/bitmap.c | inode->i_count = 1; |
inode | 324 | fs/xiafs/bitmap.c | inode->i_nlink = 1; |
inode | 325 | fs/xiafs/bitmap.c | inode->i_dev = sb->s_dev; |
inode | 326 | fs/xiafs/bitmap.c | inode->i_uid = current->fsuid; |
inode | 327 | fs/xiafs/bitmap.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 328 | fs/xiafs/bitmap.c | inode->i_dirt = 1; |
inode | 329 | fs/xiafs/bitmap.c | inode->i_ino = tmp; |
inode | 330 | fs/xiafs/bitmap.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 331 | fs/xiafs/bitmap.c | inode->i_op = NULL; |
inode | 332 | fs/xiafs/bitmap.c | inode->i_blocks = 0; |
inode | 333 | fs/xiafs/bitmap.c | inode->i_blksize = XIAFS_ZSIZE(inode->i_sb); |
inode | 334 | fs/xiafs/bitmap.c | insert_inode_hash(inode); |
inode | 335 | fs/xiafs/bitmap.c | return inode; |
inode | 23 | fs/xiafs/dir.c | static int xiafs_dir_read(struct inode *, struct file *, char *, int); |
inode | 24 | fs/xiafs/dir.c | static int xiafs_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 62 | fs/xiafs/dir.c | static int xiafs_dir_read(struct inode * inode, |
inode | 68 | fs/xiafs/dir.c | static int xiafs_readdir(struct inode * inode, struct file * filp, |
inode | 75 | fs/xiafs/dir.c | if (!inode || !inode->i_sb || !S_ISDIR(inode->i_mode)) |
inode | 77 | fs/xiafs/dir.c | if (inode->i_size & (XIAFS_ZSIZE(inode->i_sb) - 1) ) |
inode | 79 | fs/xiafs/dir.c | while (filp->f_pos < inode->i_size) { |
inode | 80 | fs/xiafs/dir.c | offset = filp->f_pos & (XIAFS_ZSIZE(inode->i_sb) - 1); |
inode | 81 | fs/xiafs/dir.c | bh = xiafs_bread(inode, filp->f_pos >> XIAFS_ZSIZE_BITS(inode->i_sb),0); |
inode | 83 | fs/xiafs/dir.c | filp->f_pos += XIAFS_ZSIZE(inode->i_sb)-offset; |
inode | 86 | fs/xiafs/dir.c | for (i = 0; i < XIAFS_ZSIZE(inode->i_sb) && i < offset; ) { |
inode | 95 | fs/xiafs/dir.c | while (offset < XIAFS_ZSIZE(inode->i_sb) && filp->f_pos < inode->i_size) { |
inode | 96 | fs/xiafs/dir.c | if (de->d_ino > inode->i_sb->u.xiafs_sb.s_ninodes || |
inode | 98 | fs/xiafs/dir.c | (char *)de+de->d_rec_len > XIAFS_ZSIZE(inode->i_sb)+bh->b_data || |
inode | 107 | fs/xiafs/dir.c | if (!IS_RDONLY (inode)) { |
inode | 108 | fs/xiafs/dir.c | inode->i_atime=CURRENT_TIME; |
inode | 109 | fs/xiafs/dir.c | inode->i_dirt=1; |
inode | 121 | fs/xiafs/dir.c | if (offset > XIAFS_ZSIZE(inode->i_sb)) { |
inode | 126 | fs/xiafs/dir.c | if (!IS_RDONLY (inode)) { |
inode | 127 | fs/xiafs/dir.c | inode->i_atime=CURRENT_TIME; |
inode | 128 | fs/xiafs/dir.c | inode->i_dirt=1; |
inode | 32 | fs/xiafs/file.c | static int xiafs_file_read(struct inode *, struct file *, char *, int); |
inode | 33 | fs/xiafs/file.c | static int xiafs_file_write(struct inode *, struct file *, const char *, int); |
inode | 73 | fs/xiafs/file.c | xiafs_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 82 | fs/xiafs/file.c | if (!inode) { |
inode | 86 | fs/xiafs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 91 | fs/xiafs/file.c | left = inode->i_size - offset; |
inode | 97 | fs/xiafs/file.c | zone_nr = offset >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 98 | fs/xiafs/file.c | offset &= XIAFS_ZSIZE(inode->i_sb) -1 ; |
inode | 99 | fs/xiafs/file.c | f_zones =(inode->i_size+XIAFS_ZSIZE(inode->i_sb)-1)>>XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 100 | fs/xiafs/file.c | zones = (left+offset+XIAFS_ZSIZE(inode->i_sb)-1) >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 103 | fs/xiafs/file.c | if(zones < read_ahead[MAJOR(inode->i_dev)] >> (1+XIAFS_ZSHIFT(inode->i_sb))) |
inode | 104 | fs/xiafs/file.c | zones = read_ahead[MAJOR(inode->i_dev)] >> (1+XIAFS_ZSHIFT(inode->i_sb)); |
inode | 123 | fs/xiafs/file.c | *bhb = xiafs_getblk(inode, zone_nr++, 0); |
inode | 155 | fs/xiafs/file.c | if (left < XIAFS_ZSIZE(inode->i_sb) - offset) |
inode | 158 | fs/xiafs/file.c | chars = XIAFS_ZSIZE(inode->i_sb) - offset; |
inode | 185 | fs/xiafs/file.c | if (!IS_RDONLY (inode)) { |
inode | 186 | fs/xiafs/file.c | inode->i_atime = CURRENT_TIME; |
inode | 187 | fs/xiafs/file.c | inode->i_dirt = 1; |
inode | 193 | fs/xiafs/file.c | xiafs_file_write(struct inode * inode, struct file * filp, const char * buf, int count) |
inode | 200 | fs/xiafs/file.c | if (!inode) { |
inode | 204 | fs/xiafs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 213 | fs/xiafs/file.c | pos = inode->i_size; |
inode | 218 | fs/xiafs/file.c | bh = xiafs_getblk(inode, pos >> XIAFS_ZSIZE_BITS(inode->i_sb), 1); |
inode | 224 | fs/xiafs/file.c | c = XIAFS_ZSIZE(inode->i_sb) - (pos & (XIAFS_ZSIZE(inode->i_sb) - 1)); |
inode | 227 | fs/xiafs/file.c | if (c != XIAFS_ZSIZE(inode->i_sb) && !buffer_uptodate(bh)) { |
inode | 237 | fs/xiafs/file.c | cp = (pos & (XIAFS_ZSIZE(inode->i_sb)-1)) + bh->b_data; |
inode | 239 | fs/xiafs/file.c | update_vm_cache(inode,pos,cp,c); |
inode | 241 | fs/xiafs/file.c | if (pos > inode->i_size) { |
inode | 242 | fs/xiafs/file.c | inode->i_size = pos; |
inode | 243 | fs/xiafs/file.c | inode->i_dirt = 1; |
inode | 251 | fs/xiafs/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 253 | fs/xiafs/file.c | inode->i_dirt = 1; |
inode | 26 | fs/xiafs/fsync.c | #define blocksize (XIAFS_ZSIZE(inode->i_sb)) |
inode | 27 | fs/xiafs/fsync.c | #define addr_per_block (XIAFS_ADDRS_PER_Z(inode->i_sb)) |
inode | 29 | fs/xiafs/fsync.c | static int sync_block (struct inode * inode, unsigned long * block, int wait) |
inode | 37 | fs/xiafs/fsync.c | bh = get_hash_table(inode->i_dev, *block, blocksize); |
inode | 58 | fs/xiafs/fsync.c | static int sync_iblock (struct inode * inode, unsigned long * iblock, |
inode | 67 | fs/xiafs/fsync.c | rc = sync_block (inode, iblock, wait); |
inode | 70 | fs/xiafs/fsync.c | *bh = bread(inode->i_dev, tmp, blocksize); |
inode | 82 | fs/xiafs/fsync.c | static int sync_direct(struct inode *inode, int wait) |
inode | 88 | fs/xiafs/fsync.c | rc = sync_block (inode, inode->u.ext_i.i_data + i, wait); |
inode | 97 | fs/xiafs/fsync.c | static int sync_indirect(struct inode *inode, unsigned long *iblock, int wait) |
inode | 103 | fs/xiafs/fsync.c | rc = sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 108 | fs/xiafs/fsync.c | rc = sync_block (inode, |
inode | 120 | fs/xiafs/fsync.c | static int sync_dindirect(struct inode *inode, unsigned long *diblock, |
inode | 127 | fs/xiafs/fsync.c | rc = sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 132 | fs/xiafs/fsync.c | rc = sync_indirect (inode, |
inode | 144 | fs/xiafs/fsync.c | int xiafs_sync_file(struct inode * inode, struct file * file) |
inode | 148 | fs/xiafs/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 149 | fs/xiafs/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 153 | fs/xiafs/fsync.c | err |= sync_direct(inode, wait); |
inode | 154 | fs/xiafs/fsync.c | err |= sync_indirect(inode, &inode->u.xiafs_i.i_ind_zone, wait); |
inode | 155 | fs/xiafs/fsync.c | err |= sync_dindirect(inode, &inode->u.xiafs_i.i_dind_zone, wait); |
inode | 157 | fs/xiafs/fsync.c | err |= xiafs_sync_inode (inode); |
inode | 28 | fs/xiafs/inode.c | void xiafs_put_inode(struct inode *inode) |
inode | 30 | fs/xiafs/inode.c | if (inode->i_nlink) |
inode | 32 | fs/xiafs/inode.c | inode->i_size = 0; |
inode | 33 | fs/xiafs/inode.c | xiafs_truncate(inode); |
inode | 34 | fs/xiafs/inode.c | xiafs_free_inode(inode); |
inode | 195 | fs/xiafs/inode.c | int xiafs_bmap(struct inode * inode,int zone) |
inode | 203 | fs/xiafs/inode.c | if (zone >= 8+(1+XIAFS_ADDRS_PER_Z(inode->i_sb))*XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 207 | fs/xiafs/inode.c | if (!IS_RDONLY (inode)) { |
inode | 208 | fs/xiafs/inode.c | inode->i_atime = CURRENT_TIME; |
inode | 209 | fs/xiafs/inode.c | inode->i_dirt = 1; |
inode | 212 | fs/xiafs/inode.c | return inode->u.xiafs_i.i_zone[zone]; |
inode | 214 | fs/xiafs/inode.c | if (zone < XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 215 | fs/xiafs/inode.c | i = inode->u.xiafs_i.i_ind_zone; |
inode | 217 | fs/xiafs/inode.c | i = zone_bmap(bread(inode->i_dev, i, XIAFS_ZSIZE(inode->i_sb)), zone); |
inode | 220 | fs/xiafs/inode.c | zone -= XIAFS_ADDRS_PER_Z(inode->i_sb); |
inode | 221 | fs/xiafs/inode.c | i = inode->u.xiafs_i.i_dind_zone; |
inode | 223 | fs/xiafs/inode.c | i = zone_bmap(bread(inode->i_dev, i, XIAFS_ZSIZE(inode->i_sb)), |
inode | 224 | fs/xiafs/inode.c | zone >> XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)); |
inode | 226 | fs/xiafs/inode.c | i= zone_bmap(bread(inode->i_dev,i, XIAFS_ZSIZE(inode->i_sb)), |
inode | 227 | fs/xiafs/inode.c | zone & (XIAFS_ADDRS_PER_Z(inode->i_sb)-1)); |
inode | 231 | fs/xiafs/inode.c | static u_long get_prev_addr(struct inode * inode, int zone) |
inode | 237 | fs/xiafs/inode.c | if ((tmp=xiafs_bmap(inode, zone))) |
inode | 239 | fs/xiafs/inode.c | random_nr=(random_nr+23)%inode->i_sb->u.xiafs_sb.s_ndatazones; |
inode | 240 | fs/xiafs/inode.c | return random_nr + inode->i_sb->u.xiafs_sb.s_firstdatazone; |
inode | 244 | fs/xiafs/inode.c | dt_getblk(struct inode * inode, u_long *lp, int create, u_long prev_addr) |
inode | 251 | fs/xiafs/inode.c | result = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 259 | fs/xiafs/inode.c | tmp = xiafs_new_zone(inode->i_sb, prev_addr); |
inode | 262 | fs/xiafs/inode.c | result = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 264 | fs/xiafs/inode.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 269 | fs/xiafs/inode.c | inode->i_blocks+=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 274 | fs/xiafs/inode.c | indt_getblk(struct inode * inode, struct buffer_head * bh, |
inode | 294 | fs/xiafs/inode.c | result = getblk(bh->b_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 306 | fs/xiafs/inode.c | tmp = xiafs_new_zone(inode->i_sb, prev_addr); |
inode | 311 | fs/xiafs/inode.c | result = getblk(bh->b_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 313 | fs/xiafs/inode.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 318 | fs/xiafs/inode.c | inode->i_blocks+=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 324 | fs/xiafs/inode.c | struct buffer_head * xiafs_getblk(struct inode * inode, int zone, int create) |
inode | 333 | fs/xiafs/inode.c | if (zone >= 8+(1+XIAFS_ADDRS_PER_Z(inode->i_sb))*XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 339 | fs/xiafs/inode.c | prev_addr=get_prev_addr(inode, zone); |
inode | 341 | fs/xiafs/inode.c | return dt_getblk(inode, zone+inode->u.xiafs_i.i_zone, create, prev_addr); |
inode | 343 | fs/xiafs/inode.c | if (zone < XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 344 | fs/xiafs/inode.c | bh = dt_getblk(inode, &(inode->u.xiafs_i.i_ind_zone), create, prev_addr); |
inode | 345 | fs/xiafs/inode.c | bh = indt_getblk(inode, bh, zone, create, prev_addr); |
inode | 348 | fs/xiafs/inode.c | zone -= XIAFS_ADDRS_PER_Z(inode->i_sb); |
inode | 349 | fs/xiafs/inode.c | bh = dt_getblk(inode, &(inode->u.xiafs_i.i_dind_zone), create, prev_addr); |
inode | 350 | fs/xiafs/inode.c | bh = indt_getblk(inode, bh, zone>>XIAFS_ADDRS_PER_Z_BITS(inode->i_sb), |
inode | 352 | fs/xiafs/inode.c | bh = indt_getblk(inode, bh, zone&(XIAFS_ADDRS_PER_Z(inode->i_sb)-1), |
inode | 357 | fs/xiafs/inode.c | struct buffer_head * xiafs_bread(struct inode * inode, int zone, int create) |
inode | 361 | fs/xiafs/inode.c | bh = xiafs_getblk(inode, zone, create); |
inode | 372 | fs/xiafs/inode.c | void xiafs_read_inode(struct inode * inode) |
inode | 379 | fs/xiafs/inode.c | ino = inode->i_ino; |
inode | 380 | fs/xiafs/inode.c | inode->i_op = NULL; |
inode | 381 | fs/xiafs/inode.c | inode->i_mode=0; |
inode | 382 | fs/xiafs/inode.c | if (!ino || ino > inode->i_sb->u.xiafs_sb.s_ninodes) { |
inode | 386 | fs/xiafs/inode.c | zone = 1 + inode->i_sb->u.xiafs_sb.s_imap_zones + |
inode | 387 | fs/xiafs/inode.c | inode->i_sb->u.xiafs_sb.s_zmap_zones + |
inode | 388 | fs/xiafs/inode.c | (ino-1)/ XIAFS_INODES_PER_Z(inode->i_sb); |
inode | 389 | fs/xiafs/inode.c | if (!(bh=bread(inode->i_dev, zone, XIAFS_ZSIZE(inode->i_sb)))) { |
inode | 394 | fs/xiafs/inode.c | ((ino-1) & (XIAFS_INODES_PER_Z(inode->i_sb) - 1)); |
inode | 395 | fs/xiafs/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 396 | fs/xiafs/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 397 | fs/xiafs/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 398 | fs/xiafs/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 399 | fs/xiafs/inode.c | inode->i_size = raw_inode->i_size; |
inode | 400 | fs/xiafs/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 401 | fs/xiafs/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 402 | fs/xiafs/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 403 | fs/xiafs/inode.c | inode->i_blksize = XIAFS_ZSIZE(inode->i_sb); |
inode | 404 | fs/xiafs/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) { |
inode | 405 | fs/xiafs/inode.c | inode->i_blocks=0; |
inode | 406 | fs/xiafs/inode.c | inode->i_rdev = to_kdev_t(raw_inode->i_zone[0]); |
inode | 408 | fs/xiafs/inode.c | XIAFS_GET_BLOCKS(raw_inode, inode->i_blocks); |
inode | 410 | fs/xiafs/inode.c | inode->u.xiafs_i.i_zone[zone] = raw_inode->i_zone[zone] & 0xffffff; |
inode | 411 | fs/xiafs/inode.c | inode->u.xiafs_i.i_ind_zone = raw_inode->i_ind_zone & 0xffffff; |
inode | 412 | fs/xiafs/inode.c | inode->u.xiafs_i.i_dind_zone = raw_inode->i_dind_zone & 0xffffff; |
inode | 415 | fs/xiafs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 416 | fs/xiafs/inode.c | inode->i_op = &xiafs_file_inode_operations; |
inode | 417 | fs/xiafs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 418 | fs/xiafs/inode.c | inode->i_op = &xiafs_dir_inode_operations; |
inode | 419 | fs/xiafs/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 420 | fs/xiafs/inode.c | inode->i_op = &xiafs_symlink_inode_operations; |
inode | 421 | fs/xiafs/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 422 | fs/xiafs/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 423 | fs/xiafs/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 424 | fs/xiafs/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 425 | fs/xiafs/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 426 | fs/xiafs/inode.c | init_fifo(inode); |
inode | 429 | fs/xiafs/inode.c | static struct buffer_head * xiafs_update_inode(struct inode * inode) |
inode | 436 | fs/xiafs/inode.c | if (IS_RDONLY (inode)) { |
inode | 438 | fs/xiafs/inode.c | inode->i_dirt = 0; |
inode | 442 | fs/xiafs/inode.c | ino = inode->i_ino; |
inode | 443 | fs/xiafs/inode.c | if (!ino || ino > inode->i_sb->u.xiafs_sb.s_ninodes) { |
inode | 445 | fs/xiafs/inode.c | inode->i_dirt=0; |
inode | 448 | fs/xiafs/inode.c | zone = 1 + inode->i_sb->u.xiafs_sb.s_imap_zones + |
inode | 449 | fs/xiafs/inode.c | inode->i_sb->u.xiafs_sb.s_zmap_zones + |
inode | 450 | fs/xiafs/inode.c | (ino-1) / XIAFS_INODES_PER_Z(inode->i_sb); |
inode | 451 | fs/xiafs/inode.c | if (!(bh=bread(inode->i_dev, zone, XIAFS_ZSIZE(inode->i_sb)))) { |
inode | 453 | fs/xiafs/inode.c | inode->i_dirt=0; |
inode | 457 | fs/xiafs/inode.c | ((ino-1) & (XIAFS_INODES_PER_Z(inode->i_sb) -1)); |
inode | 458 | fs/xiafs/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 459 | fs/xiafs/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 460 | fs/xiafs/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 461 | fs/xiafs/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 462 | fs/xiafs/inode.c | raw_inode->i_size = inode->i_size; |
inode | 463 | fs/xiafs/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 464 | fs/xiafs/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 465 | fs/xiafs/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 466 | fs/xiafs/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 467 | fs/xiafs/inode.c | raw_inode->i_zone[0] = kdev_t_to_nr(inode->i_rdev); |
inode | 469 | fs/xiafs/inode.c | XIAFS_PUT_BLOCKS(raw_inode, inode->i_blocks); |
inode | 472 | fs/xiafs/inode.c | | (inode->u.xiafs_i.i_zone[zone] & 0xffffff); |
inode | 474 | fs/xiafs/inode.c | | (inode->u.xiafs_i.i_ind_zone & 0xffffff); |
inode | 476 | fs/xiafs/inode.c | | (inode->u.xiafs_i.i_dind_zone & 0xffffff); |
inode | 478 | fs/xiafs/inode.c | inode->i_dirt=0; |
inode | 484 | fs/xiafs/inode.c | void xiafs_write_inode(struct inode * inode) |
inode | 487 | fs/xiafs/inode.c | bh = xiafs_update_inode(inode); |
inode | 491 | fs/xiafs/inode.c | int xiafs_sync_inode (struct inode *inode) |
inode | 496 | fs/xiafs/inode.c | bh = xiafs_update_inode(inode); |
inode | 504 | fs/xiafs/inode.c | kdevname(inode->i_dev), inode->i_ino); |
inode | 58 | fs/xiafs/namei.c | xiafs_find_entry(struct inode * inode, const char * name, int namelen, |
inode | 66 | fs/xiafs/namei.c | if (!inode) |
inode | 71 | fs/xiafs/namei.c | if (inode->i_size & (XIAFS_ZSIZE(inode->i_sb) - 1)) { |
inode | 75 | fs/xiafs/namei.c | zones=inode->i_size >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 77 | fs/xiafs/namei.c | bh = xiafs_bread(inode, i, 0); |
inode | 88 | fs/xiafs/namei.c | while ( pos < XIAFS_ZSIZE(inode->i_sb) ) { |
inode | 89 | fs/xiafs/namei.c | if (dep->d_ino > inode->i_sb->u.xiafs_sb.s_ninodes || |
inode | 91 | fs/xiafs/namei.c | dep->d_rec_len+(char *)dep > bh->b_data+XIAFS_ZSIZE(inode->i_sb) || |
inode | 108 | fs/xiafs/namei.c | if (pos > XIAFS_ZSIZE(inode->i_sb)) { |
inode | 116 | fs/xiafs/namei.c | int xiafs_lookup(struct inode * dir, const char * name, int len, |
inode | 117 | fs/xiafs/namei.c | struct inode ** result) |
inode | 154 | fs/xiafs/namei.c | static struct buffer_head * xiafs_add_entry(struct inode * dir, |
inode | 245 | fs/xiafs/namei.c | int xiafs_create(struct inode * dir, const char * name, int len, int mode, |
inode | 246 | fs/xiafs/namei.c | struct inode ** result) |
inode | 248 | fs/xiafs/namei.c | struct inode * inode; |
inode | 255 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
inode | 256 | fs/xiafs/namei.c | if (!inode) { |
inode | 260 | fs/xiafs/namei.c | inode->i_op = &xiafs_file_inode_operations; |
inode | 261 | fs/xiafs/namei.c | inode->i_mode = mode; |
inode | 262 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 265 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 266 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 267 | fs/xiafs/namei.c | iput(inode); |
inode | 271 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 275 | fs/xiafs/namei.c | *result = inode; |
inode | 279 | fs/xiafs/namei.c | int xiafs_mknod(struct inode *dir, const char *name, int len, int mode, int rdev) |
inode | 281 | fs/xiafs/namei.c | struct inode * inode; |
inode | 293 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
inode | 294 | fs/xiafs/namei.c | if (!inode) { |
inode | 298 | fs/xiafs/namei.c | inode->i_uid = current->fsuid; |
inode | 299 | fs/xiafs/namei.c | inode->i_mode = mode; |
inode | 300 | fs/xiafs/namei.c | inode->i_op = NULL; |
inode | 301 | fs/xiafs/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 302 | fs/xiafs/namei.c | inode->i_op = &xiafs_file_inode_operations; |
inode | 303 | fs/xiafs/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 304 | fs/xiafs/namei.c | inode->i_op = &xiafs_dir_inode_operations; |
inode | 306 | fs/xiafs/namei.c | inode->i_mode |= S_ISGID; |
inode | 308 | fs/xiafs/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 309 | fs/xiafs/namei.c | inode->i_op = &xiafs_symlink_inode_operations; |
inode | 310 | fs/xiafs/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 311 | fs/xiafs/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 312 | fs/xiafs/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 313 | fs/xiafs/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 314 | fs/xiafs/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 315 | fs/xiafs/namei.c | init_fifo(inode); |
inode | 317 | fs/xiafs/namei.c | inode->i_rdev = to_kdev_t(rdev); |
inode | 318 | fs/xiafs/namei.c | inode->i_atime = inode->i_ctime = inode->i_atime = CURRENT_TIME; |
inode | 319 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 322 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 323 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 324 | fs/xiafs/namei.c | iput(inode); |
inode | 328 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 332 | fs/xiafs/namei.c | iput(inode); |
inode | 336 | fs/xiafs/namei.c | int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 338 | fs/xiafs/namei.c | struct inode * inode; |
inode | 352 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
inode | 353 | fs/xiafs/namei.c | if (!inode) { |
inode | 357 | fs/xiafs/namei.c | inode->i_op = &xiafs_dir_inode_operations; |
inode | 358 | fs/xiafs/namei.c | inode->i_size = XIAFS_ZSIZE(dir->i_sb); |
inode | 359 | fs/xiafs/namei.c | inode->i_atime = inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 360 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 361 | fs/xiafs/namei.c | dir_block = xiafs_bread(inode,0,1); |
inode | 364 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 365 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 366 | fs/xiafs/namei.c | iput(inode); |
inode | 370 | fs/xiafs/namei.c | de->d_ino=inode->i_ino; |
inode | 379 | fs/xiafs/namei.c | inode->i_nlink = 2; |
inode | 382 | fs/xiafs/namei.c | inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->fs->umask); |
inode | 384 | fs/xiafs/namei.c | inode->i_mode |= S_ISGID; |
inode | 385 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 389 | fs/xiafs/namei.c | inode->i_nlink=0; |
inode | 390 | fs/xiafs/namei.c | iput(inode); |
inode | 393 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 398 | fs/xiafs/namei.c | iput(inode); |
inode | 406 | fs/xiafs/namei.c | static int empty_dir(struct inode * inode) |
inode | 412 | fs/xiafs/namei.c | if (inode->i_size & (XIAFS_ZSIZE(inode->i_sb)-1) ) { |
inode | 417 | fs/xiafs/namei.c | zones=inode->i_size >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 419 | fs/xiafs/namei.c | bh = xiafs_bread(inode, i, 0); |
inode | 426 | fs/xiafs/namei.c | if (de->d_ino != inode->i_ino || strcmp(".", de->d_name) || |
inode | 444 | fs/xiafs/namei.c | while (offset < XIAFS_ZSIZE(inode->i_sb)) { |
inode | 446 | fs/xiafs/namei.c | if (de->d_ino > inode->i_sb->u.xiafs_sb.s_ninodes || |
inode | 448 | fs/xiafs/namei.c | (char *)de+de->d_rec_len > bh->b_data+XIAFS_ZSIZE(inode->i_sb) || |
inode | 486 | fs/xiafs/namei.c | int xiafs_rmdir(struct inode * dir, const char * name, int len) |
inode | 489 | fs/xiafs/namei.c | struct inode * inode; |
inode | 493 | fs/xiafs/namei.c | inode = NULL; |
inode | 499 | fs/xiafs/namei.c | if (!(inode = iget(dir->i_sb, de->d_ino))) |
inode | 502 | fs/xiafs/namei.c | current->fsuid != inode->i_uid && |
inode | 505 | fs/xiafs/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 507 | fs/xiafs/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 509 | fs/xiafs/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 513 | fs/xiafs/namei.c | if (!empty_dir(inode)) { |
inode | 517 | fs/xiafs/namei.c | if (inode->i_count > 1) { |
inode | 521 | fs/xiafs/namei.c | if (inode->i_nlink != 2) |
inode | 525 | fs/xiafs/namei.c | inode->i_nlink=0; |
inode | 526 | fs/xiafs/namei.c | inode->i_dirt=1; |
inode | 528 | fs/xiafs/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 533 | fs/xiafs/namei.c | iput(inode); |
inode | 538 | fs/xiafs/namei.c | int xiafs_unlink(struct inode * dir, const char * name, int len) |
inode | 541 | fs/xiafs/namei.c | struct inode * inode; |
inode | 547 | fs/xiafs/namei.c | inode = NULL; |
inode | 551 | fs/xiafs/namei.c | if (!(inode = iget(dir->i_sb, de->d_ino))) |
inode | 554 | fs/xiafs/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 556 | fs/xiafs/namei.c | if (de->d_ino != inode->i_ino) { |
inode | 557 | fs/xiafs/namei.c | iput(inode); |
inode | 564 | fs/xiafs/namei.c | current->fsuid != inode->i_uid && |
inode | 567 | fs/xiafs/namei.c | if (!inode->i_nlink) { |
inode | 569 | fs/xiafs/namei.c | inode->i_nlink=1; |
inode | 573 | fs/xiafs/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 575 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 576 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 580 | fs/xiafs/namei.c | iput(inode); |
inode | 585 | fs/xiafs/namei.c | int xiafs_symlink(struct inode * dir, const char * name, |
inode | 589 | fs/xiafs/namei.c | struct inode * inode = NULL; |
inode | 600 | fs/xiafs/namei.c | if (!(inode = xiafs_new_inode(dir))) { |
inode | 604 | fs/xiafs/namei.c | inode->i_mode = S_IFLNK | S_IRWXUGO; |
inode | 605 | fs/xiafs/namei.c | inode->i_op = &xiafs_symlink_inode_operations; |
inode | 606 | fs/xiafs/namei.c | name_block = xiafs_bread(inode,0,1); |
inode | 609 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 610 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 611 | fs/xiafs/namei.c | iput(inode); |
inode | 619 | fs/xiafs/namei.c | inode->i_size = i; |
inode | 620 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 623 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 624 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 625 | fs/xiafs/namei.c | iput(inode); |
inode | 629 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 633 | fs/xiafs/namei.c | iput(inode); |
inode | 637 | fs/xiafs/namei.c | int xiafs_link(struct inode * oldinode, struct inode * dir, |
inode | 677 | fs/xiafs/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 714 | fs/xiafs/namei.c | static int do_xiafs_rename(struct inode * old_dir, const char * old_name, |
inode | 715 | fs/xiafs/namei.c | int old_len, struct inode * new_dir, |
inode | 718 | fs/xiafs/namei.c | struct inode * old_inode, * new_inode; |
inode | 834 | fs/xiafs/namei.c | int xiafs_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 835 | fs/xiafs/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 21 | fs/xiafs/symlink.c | xiafs_readlink(struct inode *, char *, int); |
inode | 24 | fs/xiafs/symlink.c | xiafs_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 49 | fs/xiafs/symlink.c | static int xiafs_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 55 | fs/xiafs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 56 | fs/xiafs/symlink.c | iput(inode); |
inode | 61 | fs/xiafs/symlink.c | bh = xiafs_bread(inode, 0, 0); |
inode | 62 | fs/xiafs/symlink.c | if (!IS_RDONLY (inode)) { |
inode | 63 | fs/xiafs/symlink.c | inode->i_atime=CURRENT_TIME; |
inode | 64 | fs/xiafs/symlink.c | inode->i_dirt=1; |
inode | 66 | fs/xiafs/symlink.c | iput(inode); |
inode | 77 | fs/xiafs/symlink.c | static int xiafs_follow_link(struct inode * dir, struct inode * inode, |
inode | 78 | fs/xiafs/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 88 | fs/xiafs/symlink.c | if (!inode) { |
inode | 92 | fs/xiafs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 94 | fs/xiafs/symlink.c | *res_inode = inode; |
inode | 97 | fs/xiafs/symlink.c | if (!IS_RDONLY (inode)) { |
inode | 98 | fs/xiafs/symlink.c | inode->i_atime=CURRENT_TIME; |
inode | 99 | fs/xiafs/symlink.c | inode->i_dirt=1; |
inode | 102 | fs/xiafs/symlink.c | iput(inode); |
inode | 106 | fs/xiafs/symlink.c | if (!(bh = xiafs_bread(inode, 0, 0))) { |
inode | 107 | fs/xiafs/symlink.c | iput(inode); |
inode | 111 | fs/xiafs/symlink.c | iput(inode); |
inode | 35 | fs/xiafs/truncate.c | #define DT_ZONE ((inode->i_size + XIAFS_ZSIZE(inode->i_sb) - 1) \ |
inode | 36 | fs/xiafs/truncate.c | >> XIAFS_ZSIZE_BITS(inode->i_sb) ) |
inode | 38 | fs/xiafs/truncate.c | static int trunc_direct(struct inode * inode) |
inode | 49 | fs/xiafs/truncate.c | lp=i + inode->u.xiafs_i.i_zone; |
inode | 52 | fs/xiafs/truncate.c | bh = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 61 | fs/xiafs/truncate.c | inode->i_dirt = 1; |
inode | 62 | fs/xiafs/truncate.c | inode->i_blocks-=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 63 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 70 | fs/xiafs/truncate.c | static int trunc_indirect(struct inode * inode, int addr_off, u_long * lp) |
inode | 82 | fs/xiafs/truncate.c | ind_bh = bread(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 92 | fs/xiafs/truncate.c | for (i = INDT_ZONE<0?0:INDT_ZONE; i < XIAFS_ADDRS_PER_Z(inode->i_sb); i++) { |
inode | 98 | fs/xiafs/truncate.c | bh = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 108 | fs/xiafs/truncate.c | inode->i_blocks-= 2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 109 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 114 | fs/xiafs/truncate.c | for (i = 0; i < XIAFS_ADDRS_PER_Z(inode->i_sb) && !(*indp++); i++) ; |
inode | 115 | fs/xiafs/truncate.c | if (i >= XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 121 | fs/xiafs/truncate.c | inode->i_blocks-= 2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 122 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 129 | fs/xiafs/truncate.c | static int trunc_dindirect(struct inode * inode) |
inode | 133 | fs/xiafs/truncate.c | ((DT_ZONE-XIAFS_ADDRS_PER_Z(inode->i_sb)-8)>>XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)) |
inode | 140 | fs/xiafs/truncate.c | lp = &(inode->u.xiafs_i.i_dind_zone); |
inode | 143 | fs/xiafs/truncate.c | dind_bh = bread(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 153 | fs/xiafs/truncate.c | for (i=DINDT_ZONE<0?0:DINDT_ZONE ; i < XIAFS_ADDRS_PER_Z(inode->i_sb) ; i ++) { |
inode | 157 | fs/xiafs/truncate.c | retry |= trunc_indirect(inode, |
inode | 158 | fs/xiafs/truncate.c | 8+((1+i)<<XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)), |
inode | 163 | fs/xiafs/truncate.c | for (i = 0; i < XIAFS_ADDRS_PER_Z(inode->i_sb) && !(*dindp++); i++); |
inode | 164 | fs/xiafs/truncate.c | if (i >= XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 170 | fs/xiafs/truncate.c | inode->i_dirt = 1; |
inode | 171 | fs/xiafs/truncate.c | inode->i_blocks-=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 172 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 179 | fs/xiafs/truncate.c | void xiafs_truncate(struct inode * inode) |
inode | 183 | fs/xiafs/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 184 | fs/xiafs/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 187 | fs/xiafs/truncate.c | retry = trunc_direct(inode); |
inode | 188 | fs/xiafs/truncate.c | retry |= trunc_indirect(inode, 8, &(inode->u.xiafs_i.i_ind_zone)); |
inode | 189 | fs/xiafs/truncate.c | retry |= trunc_dindirect(inode); |
inode | 195 | fs/xiafs/truncate.c | inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 196 | fs/xiafs/truncate.c | inode->i_dirt = 1; |
inode | 21 | include/linux/affs_fs.h | #define AFFS_I2BSIZE(inode) ((inode)->i_sb->u.affs_sb.s_block_size) |
inode | 41 | include/linux/affs_fs.h | static inline struct buffer_head *affs_pread(struct inode *inode, |
inode | 44 | include/linux/affs_fs.h | int offset = inode->i_sb->u.affs_sb.s_partition_offset; |
inode | 45 | include/linux/affs_fs.h | return affs_sread (inode->i_dev, sector + offset, start); |
inode | 60 | include/linux/affs_fs.h | extern int affs_open(struct inode * inode, struct file * filp); |
inode | 61 | include/linux/affs_fs.h | extern void affs_release(struct inode * inode, struct file * filp); |
inode | 62 | include/linux/affs_fs.h | extern int affs_lookup(struct inode * dir,const char * name, int len, |
inode | 63 | include/linux/affs_fs.h | struct inode ** result); |
inode | 67 | include/linux/affs_fs.h | extern int affs_bmap(struct inode *,int); |
inode | 71 | include/linux/affs_fs.h | extern void affs_read_inode(struct inode *); |
inode | 72 | include/linux/affs_fs.h | extern void affs_put_inode(struct inode *); |
inode | 74 | include/linux/affs_fs.h | extern int affs_parent_ino(struct inode *dir); |
inode | 75 | include/linux/affs_fs.h | extern int affs_lseek(struct inode *, struct file *, off_t, int); |
inode | 76 | include/linux/affs_fs.h | extern int affs_read(struct inode *, struct file *, char *, int); |
inode | 77 | include/linux/affs_fs.h | extern int affs_file_read(struct inode *, struct file *, char *, int); |
inode | 21 | include/linux/binfmts.h | struct inode * inode; |
inode | 44 | include/linux/binfmts.h | extern int read_exec(struct inode *inode, unsigned long offset, |
inode | 47 | include/linux/binfmts.h | extern int open_inode(struct inode * inode, int mode); |
inode | 368 | include/linux/ext2_fs.h | __u32 inode; /* Inode number */ |
inode | 404 | include/linux/ext2_fs.h | extern int ext2_permission (struct inode *, int); |
inode | 407 | include/linux/ext2_fs.h | extern int ext2_new_block (const struct inode *, unsigned long, |
inode | 409 | include/linux/ext2_fs.h | extern void ext2_free_blocks (const struct inode *, unsigned long, |
inode | 418 | include/linux/ext2_fs.h | extern int ext2_check_dir_entry (const char *, struct inode *, |
inode | 423 | include/linux/ext2_fs.h | extern int ext2_read (struct inode *, struct file *, char *, int); |
inode | 424 | include/linux/ext2_fs.h | extern int ext2_write (struct inode *, struct file *, char *, int); |
inode | 427 | include/linux/ext2_fs.h | extern int ext2_sync_file (struct inode *, struct file *); |
inode | 430 | include/linux/ext2_fs.h | extern struct inode * ext2_new_inode (const struct inode *, int, int *); |
inode | 431 | include/linux/ext2_fs.h | extern void ext2_free_inode (struct inode *); |
inode | 436 | include/linux/ext2_fs.h | extern int ext2_bmap (struct inode *, int); |
inode | 438 | include/linux/ext2_fs.h | extern struct buffer_head * ext2_getblk (struct inode *, long, int, int *); |
inode | 439 | include/linux/ext2_fs.h | extern struct buffer_head * ext2_bread (struct inode *, int, int, int *); |
inode | 441 | include/linux/ext2_fs.h | extern int ext2_getcluster (struct inode * inode, long block); |
inode | 442 | include/linux/ext2_fs.h | extern void ext2_read_inode (struct inode *); |
inode | 443 | include/linux/ext2_fs.h | extern void ext2_write_inode (struct inode *); |
inode | 444 | include/linux/ext2_fs.h | extern void ext2_put_inode (struct inode *); |
inode | 445 | include/linux/ext2_fs.h | extern int ext2_sync_inode (struct inode *); |
inode | 446 | include/linux/ext2_fs.h | extern void ext2_discard_prealloc (struct inode *); |
inode | 449 | include/linux/ext2_fs.h | extern int ext2_ioctl (struct inode *, struct file *, unsigned int, |
inode | 453 | include/linux/ext2_fs.h | extern void ext2_release (struct inode *, struct file *); |
inode | 454 | include/linux/ext2_fs.h | extern int ext2_lookup (struct inode *,const char *, int, struct inode **); |
inode | 455 | include/linux/ext2_fs.h | extern int ext2_create (struct inode *,const char *, int, int, |
inode | 456 | include/linux/ext2_fs.h | struct inode **); |
inode | 457 | include/linux/ext2_fs.h | extern int ext2_mkdir (struct inode *, const char *, int, int); |
inode | 458 | include/linux/ext2_fs.h | extern int ext2_rmdir (struct inode *, const char *, int); |
inode | 459 | include/linux/ext2_fs.h | extern int ext2_unlink (struct inode *, const char *, int); |
inode | 460 | include/linux/ext2_fs.h | extern int ext2_symlink (struct inode *, const char *, int, const char *); |
inode | 461 | include/linux/ext2_fs.h | extern int ext2_link (struct inode *, struct inode *, const char *, int); |
inode | 462 | include/linux/ext2_fs.h | extern int ext2_mknod (struct inode *, const char *, int, int, int); |
inode | 463 | include/linux/ext2_fs.h | extern int ext2_rename (struct inode *, const char *, int, |
inode | 464 | include/linux/ext2_fs.h | struct inode *, const char *, int); |
inode | 482 | include/linux/ext2_fs.h | extern void ext2_truncate (struct inode *); |
inode | 56 | include/linux/ext_fs.h | unsigned long inode; |
inode | 63 | include/linux/ext_fs.h | extern int ext_open(struct inode * inode, struct file * filp); |
inode | 64 | include/linux/ext_fs.h | extern void ext_release(struct inode * inode, struct file * filp); |
inode | 65 | include/linux/ext_fs.h | extern int ext_lookup(struct inode * dir,const char * name, int len, |
inode | 66 | include/linux/ext_fs.h | struct inode ** result); |
inode | 67 | include/linux/ext_fs.h | extern int ext_create(struct inode * dir,const char * name, int len, int mode, |
inode | 68 | include/linux/ext_fs.h | struct inode ** result); |
inode | 69 | include/linux/ext_fs.h | extern int ext_mkdir(struct inode * dir, const char * name, int len, int mode); |
inode | 70 | include/linux/ext_fs.h | extern int ext_rmdir(struct inode * dir, const char * name, int len); |
inode | 71 | include/linux/ext_fs.h | extern int ext_unlink(struct inode * dir, const char * name, int len); |
inode | 72 | include/linux/ext_fs.h | extern int ext_symlink(struct inode * inode, const char * name, int len, |
inode | 74 | include/linux/ext_fs.h | extern int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
inode | 75 | include/linux/ext_fs.h | extern int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
inode | 76 | include/linux/ext_fs.h | extern int ext_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 77 | include/linux/ext_fs.h | struct inode * new_dir, const char * new_name, int new_len); |
inode | 78 | include/linux/ext_fs.h | extern struct inode * ext_new_inode(const struct inode * dir); |
inode | 79 | include/linux/ext_fs.h | extern void ext_free_inode(struct inode * inode); |
inode | 85 | include/linux/ext_fs.h | extern int ext_bmap(struct inode *,int); |
inode | 87 | include/linux/ext_fs.h | extern struct buffer_head * ext_getblk(struct inode *, int, int); |
inode | 88 | include/linux/ext_fs.h | extern struct buffer_head * ext_bread(struct inode *, int, int); |
inode | 90 | include/linux/ext_fs.h | extern void ext_truncate(struct inode *); |
inode | 95 | include/linux/ext_fs.h | extern void ext_read_inode(struct inode *); |
inode | 96 | include/linux/ext_fs.h | extern void ext_write_inode(struct inode *); |
inode | 97 | include/linux/ext_fs.h | extern void ext_put_inode(struct inode *); |
inode | 99 | include/linux/ext_fs.h | extern int ext_sync_inode(struct inode *); |
inode | 100 | include/linux/ext_fs.h | extern int ext_sync_file(struct inode *, struct file *); |
inode | 102 | include/linux/ext_fs.h | extern int ext_lseek(struct inode *, struct file *, off_t, int); |
inode | 103 | include/linux/ext_fs.h | extern int ext_read(struct inode *, struct file *, char *, int); |
inode | 104 | include/linux/ext_fs.h | extern int ext_write(struct inode *, struct file *, char *, int); |
inode | 145 | include/linux/fb.h | int (*fb_ioctl)(struct inode *, struct file *, unsigned int, |
inode | 95 | include/linux/fs.h | #define IS_RDONLY(inode) (((inode)->i_sb) && ((inode)->i_sb->s_flags & MS_RDONLY)) |
inode | 96 | include/linux/fs.h | #define IS_NOSUID(inode) ((inode)->i_flags & MS_NOSUID) |
inode | 97 | include/linux/fs.h | #define IS_NODEV(inode) ((inode)->i_flags & MS_NODEV) |
inode | 98 | include/linux/fs.h | #define IS_NOEXEC(inode) ((inode)->i_flags & MS_NOEXEC) |
inode | 99 | include/linux/fs.h | #define IS_SYNC(inode) ((inode)->i_flags & MS_SYNCHRONOUS) |
inode | 101 | include/linux/fs.h | #define IS_WRITABLE(inode) ((inode)->i_flags & S_WRITE) |
inode | 102 | include/linux/fs.h | #define IS_APPEND(inode) ((inode)->i_flags & S_APPEND) |
inode | 103 | include/linux/fs.h | #define IS_IMMUTABLE(inode) ((inode)->i_flags & S_IMMUTABLE) |
inode | 291 | include/linux/fs.h | struct inode *i_next, *i_prev; |
inode | 292 | include/linux/fs.h | struct inode *i_hash_next, *i_hash_prev; |
inode | 293 | include/linux/fs.h | struct inode *i_bound_to, *i_bound_by; |
inode | 294 | include/linux/fs.h | struct inode *i_mount; |
inode | 331 | include/linux/fs.h | struct inode * f_inode; |
inode | 362 | include/linux/fs.h | extern int locks_mandatory_locked(struct inode *inode); |
inode | 363 | include/linux/fs.h | extern inline int locks_verify_locked(struct inode *inode) |
inode | 368 | include/linux/fs.h | if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) |
inode | 369 | include/linux/fs.h | return (locks_mandatory_locked(inode)); |
inode | 372 | include/linux/fs.h | extern int locks_mandatory_area(int read_write, struct inode *inode, |
inode | 375 | include/linux/fs.h | extern inline int locks_verify_area(int read_write, struct inode *inode, |
inode | 382 | include/linux/fs.h | if ((inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) |
inode | 383 | include/linux/fs.h | return (locks_mandatory_area(read_write, inode, filp, offset, |
inode | 396 | include/linux/fs.h | extern int fasync_helper(struct inode *, struct file *, int, struct fasync_struct **); |
inode | 423 | include/linux/fs.h | struct inode * s_covered; |
inode | 424 | include/linux/fs.h | struct inode * s_mounted; |
inode | 451 | include/linux/fs.h | int (*lseek) (struct inode *, struct file *, off_t, int); |
inode | 452 | include/linux/fs.h | int (*read) (struct inode *, struct file *, char *, int); |
inode | 453 | include/linux/fs.h | int (*write) (struct inode *, struct file *, const char *, int); |
inode | 454 | include/linux/fs.h | int (*readdir) (struct inode *, struct file *, void *, filldir_t); |
inode | 455 | include/linux/fs.h | int (*select) (struct inode *, struct file *, int, select_table *); |
inode | 456 | include/linux/fs.h | int (*ioctl) (struct inode *, struct file *, unsigned int, unsigned long); |
inode | 457 | include/linux/fs.h | int (*mmap) (struct inode *, struct file *, struct vm_area_struct *); |
inode | 458 | include/linux/fs.h | int (*open) (struct inode *, struct file *); |
inode | 459 | include/linux/fs.h | void (*release) (struct inode *, struct file *); |
inode | 460 | include/linux/fs.h | int (*fsync) (struct inode *, struct file *); |
inode | 461 | include/linux/fs.h | int (*fasync) (struct inode *, struct file *, int); |
inode | 468 | include/linux/fs.h | int (*create) (struct inode *,const char *,int,int,struct inode **); |
inode | 469 | include/linux/fs.h | int (*lookup) (struct inode *,const char *,int,struct inode **); |
inode | 470 | include/linux/fs.h | int (*link) (struct inode *,struct inode *,const char *,int); |
inode | 471 | include/linux/fs.h | int (*unlink) (struct inode *,const char *,int); |
inode | 472 | include/linux/fs.h | int (*symlink) (struct inode *,const char *,int,const char *); |
inode | 473 | include/linux/fs.h | int (*mkdir) (struct inode *,const char *,int,int); |
inode | 474 | include/linux/fs.h | int (*rmdir) (struct inode *,const char *,int); |
inode | 475 | include/linux/fs.h | int (*mknod) (struct inode *,const char *,int,int,int); |
inode | 476 | include/linux/fs.h | int (*rename) (struct inode *,const char *,int,struct inode *,const char *,int); |
inode | 477 | include/linux/fs.h | int (*readlink) (struct inode *,char *,int); |
inode | 478 | include/linux/fs.h | int (*follow_link) (struct inode *,struct inode *,int,int,struct inode **); |
inode | 479 | include/linux/fs.h | int (*readpage) (struct inode *, struct page *); |
inode | 480 | include/linux/fs.h | int (*writepage) (struct inode *, struct page *); |
inode | 481 | include/linux/fs.h | int (*bmap) (struct inode *,int); |
inode | 482 | include/linux/fs.h | void (*truncate) (struct inode *); |
inode | 483 | include/linux/fs.h | int (*permission) (struct inode *, int); |
inode | 484 | include/linux/fs.h | int (*smap) (struct inode *,int); |
inode | 488 | include/linux/fs.h | void (*read_inode) (struct inode *); |
inode | 489 | include/linux/fs.h | int (*notify_change) (struct inode *, struct iattr *); |
inode | 490 | include/linux/fs.h | void (*write_inode) (struct inode *); |
inode | 491 | include/linux/fs.h | void (*put_inode) (struct inode *); |
inode | 499 | include/linux/fs.h | void (*initialize) (struct inode *, short); |
inode | 500 | include/linux/fs.h | void (*drop) (struct inode *); |
inode | 501 | include/linux/fs.h | int (*alloc_block) (const struct inode *, unsigned long); |
inode | 502 | include/linux/fs.h | int (*alloc_inode) (const struct inode *, unsigned long); |
inode | 503 | include/linux/fs.h | void (*free_block) (const struct inode *, unsigned long); |
inode | 504 | include/linux/fs.h | void (*free_inode) (const struct inode *, unsigned long); |
inode | 505 | include/linux/fs.h | int (*transfer) (struct inode *, struct iattr *, char); |
inode | 525 | include/linux/fs.h | extern int do_truncate(struct inode *, unsigned long); |
inode | 528 | include/linux/fs.h | extern int blkdev_open(struct inode * inode, struct file * filp); |
inode | 529 | include/linux/fs.h | extern void blkdev_release (struct inode * inode); |
inode | 535 | include/linux/fs.h | extern int chrdev_open(struct inode * inode, struct file * filp); |
inode | 539 | include/linux/fs.h | extern void init_fifo(struct inode * inode); |
inode | 553 | include/linux/fs.h | extern int fs_may_umount(kdev_t dev, struct inode * mount_root); |
inode | 597 | include/linux/fs.h | extern void invalidate_inode_pages(struct inode *); |
inode | 604 | include/linux/fs.h | extern int bmap(struct inode * inode,int block); |
inode | 605 | include/linux/fs.h | extern int notify_change(struct inode *, struct iattr *); |
inode | 606 | include/linux/fs.h | extern int namei(const char * pathname, struct inode ** res_inode); |
inode | 607 | include/linux/fs.h | extern int lnamei(const char * pathname, struct inode ** res_inode); |
inode | 608 | include/linux/fs.h | extern int permission(struct inode * inode,int mask); |
inode | 609 | include/linux/fs.h | extern int get_write_access(struct inode *inode); |
inode | 610 | include/linux/fs.h | extern void put_write_access(struct inode *inode); |
inode | 612 | include/linux/fs.h | struct inode ** res_inode, struct inode * base); |
inode | 615 | include/linux/fs.h | extern void iput(struct inode * inode); |
inode | 616 | include/linux/fs.h | extern struct inode * __iget(struct super_block * sb,int nr,int crsmnt); |
inode | 617 | include/linux/fs.h | extern struct inode * get_empty_inode(void); |
inode | 618 | include/linux/fs.h | extern void insert_inode_hash(struct inode *); |
inode | 619 | include/linux/fs.h | extern void clear_inode(struct inode *); |
inode | 620 | include/linux/fs.h | extern struct inode * get_pipe_inode(void); |
inode | 646 | include/linux/fs.h | extern int generic_readpage(struct inode *, struct page *); |
inode | 647 | include/linux/fs.h | extern int generic_file_read(struct inode *, struct file *, char *, int); |
inode | 648 | include/linux/fs.h | extern int generic_file_mmap(struct inode *, struct file *, struct vm_area_struct *); |
inode | 663 | include/linux/fs.h | extern int char_read(struct inode *, struct file *, char *, int); |
inode | 664 | include/linux/fs.h | extern int block_read(struct inode *, struct file *, char *, int); |
inode | 667 | include/linux/fs.h | extern int char_write(struct inode *, struct file *, const char *, int); |
inode | 668 | include/linux/fs.h | extern int block_write(struct inode *, struct file *, const char *, int); |
inode | 670 | include/linux/fs.h | extern int block_fsync(struct inode *, struct file *); |
inode | 671 | include/linux/fs.h | extern int file_fsync(struct inode *, struct file *); |
inode | 673 | include/linux/fs.h | extern void dcache_add(struct inode *, const char *, int, unsigned long); |
inode | 674 | include/linux/fs.h | extern int dcache_lookup(struct inode *, const char *, int, unsigned long *); |
inode | 676 | include/linux/fs.h | extern int inode_change_ok(struct inode *, struct iattr *); |
inode | 677 | include/linux/fs.h | extern void inode_setattr(struct inode *, struct iattr *); |
inode | 679 | include/linux/fs.h | extern inline struct inode * iget(struct super_block * sb,int nr) |
inode | 159 | include/linux/iso_fs.h | extern int parse_rock_ridge_inode(struct iso_directory_record *, struct inode *); |
inode | 160 | include/linux/iso_fs.h | extern int get_rock_ridge_filename(struct iso_directory_record *, char ** name, int * len, struct inode *); |
inode | 162 | include/linux/iso_fs.h | extern char * get_rock_ridge_symlink(struct inode *); |
inode | 163 | include/linux/iso_fs.h | extern int find_rock_ridge_relocation(struct iso_directory_record *, struct inode *); |
inode | 168 | include/linux/iso_fs.h | extern int isofs_open(struct inode * inode, struct file * filp); |
inode | 169 | include/linux/iso_fs.h | extern void isofs_release(struct inode * inode, struct file * filp); |
inode | 170 | include/linux/iso_fs.h | extern int isofs_lookup(struct inode * dir,const char * name, int len, |
inode | 171 | include/linux/iso_fs.h | struct inode ** result); |
inode | 175 | include/linux/iso_fs.h | extern int isofs_bmap(struct inode *,int); |
inode | 180 | include/linux/iso_fs.h | extern void isofs_read_inode(struct inode *); |
inode | 181 | include/linux/iso_fs.h | extern void isofs_put_inode(struct inode *); |
inode | 184 | include/linux/iso_fs.h | extern int isofs_lseek(struct inode *, struct file *, off_t, int); |
inode | 185 | include/linux/iso_fs.h | extern int isofs_read(struct inode *, struct file *, char *, int); |
inode | 186 | include/linux/iso_fs.h | extern int isofs_lookup_grandparent(struct inode *, int); |
inode | 20 | include/linux/loop.h | struct inode *lo_inode; |
inode | 94 | include/linux/md.h | struct inode *inode; /* Lock inode */ |
inode | 113 | include/linux/md.h | int (*ioctl)(struct inode *inode, struct file *file, |
inode | 34 | include/linux/minix_fs.h | #define INODE_VERSION(inode) inode->i_sb->u.minix_sb.s_version |
inode | 85 | include/linux/minix_fs.h | __u16 inode; |
inode | 91 | include/linux/minix_fs.h | extern int minix_lookup(struct inode * dir,const char * name, int len, |
inode | 92 | include/linux/minix_fs.h | struct inode ** result); |
inode | 93 | include/linux/minix_fs.h | extern int minix_create(struct inode * dir,const char * name, int len, int mode, |
inode | 94 | include/linux/minix_fs.h | struct inode ** result); |
inode | 95 | include/linux/minix_fs.h | extern int minix_mkdir(struct inode * dir, const char * name, int len, int mode); |
inode | 96 | include/linux/minix_fs.h | extern int minix_rmdir(struct inode * dir, const char * name, int len); |
inode | 97 | include/linux/minix_fs.h | extern int minix_unlink(struct inode * dir, const char * name, int len); |
inode | 98 | include/linux/minix_fs.h | extern int minix_symlink(struct inode * inode, const char * name, int len, |
inode | 100 | include/linux/minix_fs.h | extern int minix_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
inode | 101 | include/linux/minix_fs.h | extern int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
inode | 102 | include/linux/minix_fs.h | extern int minix_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 103 | include/linux/minix_fs.h | struct inode * new_dir, const char * new_name, int new_len); |
inode | 104 | include/linux/minix_fs.h | extern struct inode * minix_new_inode(const struct inode * dir); |
inode | 105 | include/linux/minix_fs.h | extern void minix_free_inode(struct inode * inode); |
inode | 111 | include/linux/minix_fs.h | extern int minix_bmap(struct inode *,int); |
inode | 113 | include/linux/minix_fs.h | extern struct buffer_head * minix_getblk(struct inode *, int, int); |
inode | 114 | include/linux/minix_fs.h | extern struct buffer_head * minix_bread(struct inode *, int, int); |
inode | 116 | include/linux/minix_fs.h | extern void minix_truncate(struct inode *); |
inode | 122 | include/linux/minix_fs.h | extern void minix_read_inode(struct inode *); |
inode | 123 | include/linux/minix_fs.h | extern void minix_write_inode(struct inode *); |
inode | 124 | include/linux/minix_fs.h | extern void minix_put_inode(struct inode *); |
inode | 126 | include/linux/minix_fs.h | extern int minix_sync_inode(struct inode *); |
inode | 127 | include/linux/minix_fs.h | extern int minix_sync_file(struct inode *, struct file *); |
inode | 57 | include/linux/mm.h | struct inode * vm_inode; |
inode | 128 | include/linux/mm.h | struct inode *inode; |
inode | 266 | include/linux/mm.h | extern void vmtruncate(struct inode * inode, unsigned long offset); |
inode | 298 | include/linux/mm.h | extern void truncate_inode_pages(struct inode *, unsigned long); |
inode | 176 | include/linux/msdos_fs.h | extern int fat_add_cluster(struct inode *inode); |
inode | 182 | include/linux/msdos_fs.h | extern int fat_get_entry(struct inode *dir,loff_t *pos,struct buffer_head **bh, |
inode | 184 | include/linux/msdos_fs.h | extern int fat_scan(struct inode *dir,const char *name,struct buffer_head **res_bh, |
inode | 186 | include/linux/msdos_fs.h | extern int fat_parent_ino(struct inode *dir,int locked); |
inode | 187 | include/linux/msdos_fs.h | extern int fat_subdirs(struct inode *dir); |
inode | 191 | include/linux/msdos_fs.h | extern int fat_smap(struct inode *inode,int sector); |
inode | 192 | include/linux/msdos_fs.h | extern int fat_free(struct inode *inode,int skip); |
inode | 193 | include/linux/msdos_fs.h | void fat_cache_inval_inode(struct inode *inode); |
inode | 196 | include/linux/msdos_fs.h | void cache_lookup(struct inode *inode,int cluster,int *f_clu,int *d_clu); |
inode | 197 | include/linux/msdos_fs.h | void cache_add(struct inode *inode,int f_clu,int d_clu); |
inode | 198 | include/linux/msdos_fs.h | int get_cluster(struct inode *inode,int cluster); |
inode | 201 | include/linux/msdos_fs.h | extern int fat_bmap(struct inode *inode,int block); |
inode | 202 | include/linux/msdos_fs.h | extern int fat_notify_change(struct inode *,struct iattr *); |
inode | 203 | include/linux/msdos_fs.h | extern void fat_put_inode(struct inode *inode); |
inode | 205 | include/linux/msdos_fs.h | extern void fat_read_inode(struct inode *inode, struct inode_operations *dir_ops); |
inode | 209 | include/linux/msdos_fs.h | extern void fat_write_inode(struct inode *inode); |
inode | 213 | include/linux/msdos_fs.h | extern int fat_readdirx(struct inode *inode, struct file *filp, void *dirent, |
inode | 216 | include/linux/msdos_fs.h | extern int fat_readdir(struct inode *inode, struct file *filp, |
inode | 218 | include/linux/msdos_fs.h | extern int fat_dir_ioctl(struct inode * inode, struct file * filp, |
inode | 224 | include/linux/msdos_fs.h | extern int fat_file_read(struct inode *, struct file *, char *, int); |
inode | 225 | include/linux/msdos_fs.h | extern int fat_file_write(struct inode *, struct file *, const char *, int); |
inode | 226 | include/linux/msdos_fs.h | extern void fat_truncate(struct inode *inode); |
inode | 229 | include/linux/msdos_fs.h | extern int fat_mmap(struct inode *, struct file *, struct vm_area_struct *); |
inode | 244 | include/linux/msdos_fs.h | extern void msdos_read_inode(struct inode *inode); |
inode | 245 | include/linux/msdos_fs.h | extern int msdos_lookup(struct inode *dir,const char *name,int len, |
inode | 246 | include/linux/msdos_fs.h | struct inode **result); |
inode | 247 | include/linux/msdos_fs.h | extern int msdos_create(struct inode *dir,const char *name,int len,int mode, |
inode | 248 | include/linux/msdos_fs.h | struct inode **result); |
inode | 249 | include/linux/msdos_fs.h | extern int msdos_rmdir(struct inode *dir,const char *name,int len); |
inode | 250 | include/linux/msdos_fs.h | extern int msdos_mkdir(struct inode *dir,const char *name,int len,int mode); |
inode | 251 | include/linux/msdos_fs.h | extern int msdos_unlink(struct inode *dir,const char *name,int len); |
inode | 252 | include/linux/msdos_fs.h | extern int msdos_unlink_umsdos(struct inode *dir,const char *name,int len); |
inode | 253 | include/linux/msdos_fs.h | extern int msdos_rename(struct inode *old_dir,const char *old_name,int old_len, |
inode | 254 | include/linux/msdos_fs.h | struct inode *new_dir,const char *new_name,int new_len); |
inode | 32 | include/linux/msdos_fs_i.h | struct inode *i_depend; /* pointer to inode that depends on the |
inode | 34 | include/linux/msdos_fs_i.h | struct inode *i_old; /* pointer to the old inode this inode |
inode | 36 | include/linux/msdos_fs_i.h | struct inode *i_linked; /* pointer to inode linked to the current one, |
inode | 38 | include/linux/msdos_fs_i.h | struct inode *i_oldlink;/* pointer to open inode that references |
inode | 73 | include/linux/ncp_fs.h | #define NCP_INOP(inode) ((struct ncp_inode_info *)((inode)->u.generic_ip)) |
inode | 75 | include/linux/ncp_fs.h | #define NCP_SERVER(inode) NCP_SBP((inode)->i_sb) |
inode | 76 | include/linux/ncp_fs.h | #define NCP_FINFO(inode) (&(NCP_INOP(inode)->finfo)) |
inode | 77 | include/linux/ncp_fs.h | #define NCP_ISTRUCT(inode) (&(NCP_FINFO(inode)->i)) |
inode | 123 | include/linux/ncp_fs.h | int ncp_make_open(struct inode *i, int right); |
inode | 132 | include/linux/ncp_fs.h | void ncp_invalid_dir_cache(struct inode *ino); |
inode | 133 | include/linux/ncp_fs.h | struct ncp_inode_info *ncp_find_inode(struct inode *inode); |
inode | 141 | include/linux/ncp_fs.h | int ncp_ioctl (struct inode * inode, struct file * filp, |
inode | 161 | include/linux/ncp_fs.h | int ncp_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma); |
inode | 31 | include/linux/ncp_fs_i.h | struct inode *inode; |
inode | 81 | include/linux/net.h | struct inode *inode; |
inode | 86 | include/linux/net.h | #define SOCK_INODE(S) ((S)->inode) |
inode | 44 | include/linux/nfs_fs.h | #define NFS_SERVER(inode) (&(inode)->i_sb->u.nfs_sb.s_server) |
inode | 45 | include/linux/nfs_fs.h | #define NFS_FH(inode) (&(inode)->u.nfs_i.fhandle) |
inode | 46 | include/linux/nfs_fs.h | #define NFS_RENAMED_DIR(inode) ((inode)->u.nfs_i.silly_rename_dir) |
inode | 47 | include/linux/nfs_fs.h | #define NFS_READTIME(inode) ((inode)->u.nfs_i.read_cache_jiffies) |
inode | 48 | include/linux/nfs_fs.h | #define NFS_OLDMTIME(inode) ((inode)->u.nfs_i.read_cache_mtime) |
inode | 49 | include/linux/nfs_fs.h | #define NFS_CACHEINV(inode) \ |
inode | 51 | include/linux/nfs_fs.h | NFS_READTIME(inode) = jiffies - 1000000; \ |
inode | 52 | include/linux/nfs_fs.h | NFS_OLDMTIME(inode) = 0; \ |
inode | 73 | include/linux/nfs_fs.h | extern int nfs_proc_write(struct inode * inode, int offset, |
inode | 116 | include/linux/nfs_fs.h | extern struct inode *nfs_fhget(struct super_block *sb, struct nfs_fh *fhandle, |
inode | 118 | include/linux/nfs_fs.h | extern void nfs_refresh_inode(struct inode *inode, struct nfs_fattr *fattr); |
inode | 127 | include/linux/nfs_fs.h | extern void nfs_sillyrename_cleanup(struct inode *); |
inode | 136 | include/linux/nfs_fs.h | extern int nfs_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma); |
inode | 140 | include/linux/nfs_fs.h | extern int nfs_readpage(struct inode *, struct page *); |
inode | 30 | include/linux/nfs_fs_i.h | struct inode *silly_rename_dir; |
inode | 34 | include/linux/pagemap.h | static inline unsigned long _page_hashfn(struct inode * inode, unsigned long offset) |
inode | 36 | include/linux/pagemap.h | #define i (((unsigned long) inode)/(sizeof(struct inode) & ~ (sizeof(struct inode) - 1))) |
inode | 45 | include/linux/pagemap.h | #define page_hash(inode,offset) page_hash_table[_page_hashfn(inode,offset)] |
inode | 47 | include/linux/pagemap.h | static inline struct page * find_page(struct inode * inode, unsigned long offset) |
inode | 51 | include/linux/pagemap.h | for (page = page_hash(inode, offset); page ; page = page->next_hash) { |
inode | 52 | include/linux/pagemap.h | if (page->inode != inode) |
inode | 66 | include/linux/pagemap.h | struct page **p = &page_hash(page->inode,page->offset); |
inode | 78 | include/linux/pagemap.h | static inline void add_page_to_hash_queue(struct inode * inode, struct page * page) |
inode | 80 | include/linux/pagemap.h | struct page **p = &page_hash(inode,page->offset); |
inode | 93 | include/linux/pagemap.h | struct inode * inode = page->inode; |
inode | 95 | include/linux/pagemap.h | page->inode = NULL; |
inode | 96 | include/linux/pagemap.h | inode->i_nrpages--; |
inode | 97 | include/linux/pagemap.h | if (inode->i_pages == page) |
inode | 98 | include/linux/pagemap.h | inode->i_pages = page->next; |
inode | 107 | include/linux/pagemap.h | static inline void add_page_to_inode_queue(struct inode * inode, struct page * page) |
inode | 109 | include/linux/pagemap.h | struct page **p = &inode->i_pages; |
inode | 111 | include/linux/pagemap.h | inode->i_nrpages++; |
inode | 112 | include/linux/pagemap.h | page->inode = inode; |
inode | 126 | include/linux/pagemap.h | extern void update_vm_cache(struct inode *, unsigned long, const char *, int); |
inode | 16 | include/linux/pipe_fs_i.h | #define PIPE_WAIT(inode) ((inode).u.pipe_i.wait) |
inode | 17 | include/linux/pipe_fs_i.h | #define PIPE_BASE(inode) ((inode).u.pipe_i.base) |
inode | 18 | include/linux/pipe_fs_i.h | #define PIPE_START(inode) ((inode).u.pipe_i.start) |
inode | 19 | include/linux/pipe_fs_i.h | #define PIPE_LEN(inode) ((inode).u.pipe_i.len) |
inode | 20 | include/linux/pipe_fs_i.h | #define PIPE_RD_OPENERS(inode) ((inode).u.pipe_i.rd_openers) |
inode | 21 | include/linux/pipe_fs_i.h | #define PIPE_WR_OPENERS(inode) ((inode).u.pipe_i.wr_openers) |
inode | 22 | include/linux/pipe_fs_i.h | #define PIPE_READERS(inode) ((inode).u.pipe_i.readers) |
inode | 23 | include/linux/pipe_fs_i.h | #define PIPE_WRITERS(inode) ((inode).u.pipe_i.writers) |
inode | 24 | include/linux/pipe_fs_i.h | #define PIPE_LOCK(inode) ((inode).u.pipe_i.lock) |
inode | 25 | include/linux/pipe_fs_i.h | #define PIPE_SIZE(inode) PIPE_LEN(inode) |
inode | 27 | include/linux/pipe_fs_i.h | #define PIPE_EMPTY(inode) (PIPE_SIZE(inode)==0) |
inode | 28 | include/linux/pipe_fs_i.h | #define PIPE_FULL(inode) (PIPE_SIZE(inode)==PIPE_BUF) |
inode | 29 | include/linux/pipe_fs_i.h | #define PIPE_FREE(inode) (PIPE_BUF - PIPE_LEN(inode)) |
inode | 30 | include/linux/pipe_fs_i.h | #define PIPE_END(inode) ((PIPE_START(inode)+PIPE_LEN(inode))&\ |
inode | 32 | include/linux/pipe_fs_i.h | #define PIPE_MAX_RCHUNK(inode) (PIPE_BUF - PIPE_START(inode)) |
inode | 33 | include/linux/pipe_fs_i.h | #define PIPE_MAX_WCHUNK(inode) (PIPE_BUF - PIPE_END(inode)) |
inode | 177 | include/linux/proc_fs.h | void (*fill_inode)(struct inode *); |
inode | 247 | include/linux/proc_fs.h | extern struct inode * proc_get_inode(struct super_block *, int, struct proc_dir_entry *); |
inode | 249 | include/linux/proc_fs.h | extern void proc_read_inode(struct inode *); |
inode | 250 | include/linux/proc_fs.h | extern void proc_write_inode(struct inode *); |
inode | 260 | include/linux/proc_fs.h | extern int proc_readdir(struct inode *, struct file *, void *, filldir_t); |
inode | 261 | include/linux/proc_fs.h | extern int proc_lookup(struct inode *, const char *, int, struct inode **); |
inode | 198 | include/linux/quota.h | extern void dquot_initialize(struct inode *inode, short type); |
inode | 199 | include/linux/quota.h | extern void dquot_drop(struct inode *inode); |
inode | 200 | include/linux/quota.h | extern int dquot_alloc_block(const struct inode *inode, unsigned long number); |
inode | 201 | include/linux/quota.h | extern int dquot_alloc_inode(const struct inode *inode, unsigned long number); |
inode | 202 | include/linux/quota.h | extern void dquot_free_block(const struct inode *inode, unsigned long number); |
inode | 203 | include/linux/quota.h | extern void dquot_free_inode(const struct inode *inode, unsigned long number); |
inode | 204 | include/linux/quota.h | extern int dquot_transfer(struct inode *inode, struct iattr *iattr, char direction); |
inode | 134 | include/linux/sched.h | struct inode * root, * pwd; |
inode | 43 | include/linux/smb_fs.h | #define SMB_INOP(inode) ((struct smb_inode_info *)(inode->u.generic_ip)) |
inode | 45 | include/linux/smb_fs.h | #define SMB_SERVER(inode) (&(SMB_SBP(inode->i_sb)->s_server)) |
inode | 46 | include/linux/smb_fs.h | #define SMB_SERVATTR(inode) (&(SMB_SBP(inode->i_sb)->s_attr)) |
inode | 48 | include/linux/smb_fs.h | #define SMB_FINFO(inode) (&(SMB_INOP(inode)->finfo)) |
inode | 97 | include/linux/smb_fs.h | int smb_make_open(struct inode *i, int right); |
inode | 111 | include/linux/smb_fs.h | int smb_ioctl (struct inode * inode, struct file * filp, |
inode | 118 | include/linux/smb_fs.h | int smb_notify_change(struct inode *inode, struct iattr *attr); |
inode | 146 | include/linux/smb_fs.h | int smb_proc_readdir(struct smb_server *server, struct inode *dir, |
inode | 152 | include/linux/smb_fs.h | struct inode *ino, |
inode | 177 | include/linux/smb_fs.h | int smb_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma); |
inode | 20 | include/linux/swap.h | struct inode * swap_file; |
inode | 312 | include/linux/sysv_fs.h | sysv_ino_t inode; |
inode | 364 | include/linux/sysv_fs.h | extern int sysv_lookup(struct inode * dir,const char * name, int len, |
inode | 365 | include/linux/sysv_fs.h | struct inode ** result); |
inode | 366 | include/linux/sysv_fs.h | extern int sysv_create(struct inode * dir,const char * name, int len, int mode, |
inode | 367 | include/linux/sysv_fs.h | struct inode ** result); |
inode | 368 | include/linux/sysv_fs.h | extern int sysv_mkdir(struct inode * dir, const char * name, int len, int mode); |
inode | 369 | include/linux/sysv_fs.h | extern int sysv_rmdir(struct inode * dir, const char * name, int len); |
inode | 370 | include/linux/sysv_fs.h | extern int sysv_unlink(struct inode * dir, const char * name, int len); |
inode | 371 | include/linux/sysv_fs.h | extern int sysv_symlink(struct inode * inode, const char * name, int len, |
inode | 373 | include/linux/sysv_fs.h | extern int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
inode | 374 | include/linux/sysv_fs.h | extern int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
inode | 375 | include/linux/sysv_fs.h | extern int sysv_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 376 | include/linux/sysv_fs.h | struct inode * new_dir, const char * new_name, int new_len); |
inode | 377 | include/linux/sysv_fs.h | extern struct inode * sysv_new_inode(const struct inode * dir); |
inode | 378 | include/linux/sysv_fs.h | extern void sysv_free_inode(struct inode * inode); |
inode | 384 | include/linux/sysv_fs.h | extern int sysv_bmap(struct inode *,int); |
inode | 386 | include/linux/sysv_fs.h | extern struct buffer_head * sysv_getblk(struct inode *, unsigned int, int); |
inode | 387 | include/linux/sysv_fs.h | extern struct buffer_head * sysv_file_bread(struct inode *, int, int); |
inode | 388 | include/linux/sysv_fs.h | extern int sysv_file_read(struct inode *, struct file *, char *, int); |
inode | 390 | include/linux/sysv_fs.h | extern void sysv_truncate(struct inode *); |
inode | 395 | include/linux/sysv_fs.h | extern void sysv_read_inode(struct inode *); |
inode | 396 | include/linux/sysv_fs.h | extern int sysv_notify_change(struct inode *, struct iattr *); |
inode | 397 | include/linux/sysv_fs.h | extern void sysv_write_inode(struct inode *); |
inode | 398 | include/linux/sysv_fs.h | extern void sysv_put_inode(struct inode *); |
inode | 400 | include/linux/sysv_fs.h | extern int sysv_sync_inode(struct inode *); |
inode | 401 | include/linux/sysv_fs.h | extern int sysv_sync_file(struct inode *, struct file *); |
inode | 402 | include/linux/sysv_fs.h | extern int sysv_mmap(struct inode *, struct file *, struct vm_area_struct *); |
inode | 29 | include/linux/tty_ldisc.h | int (*select)(struct tty_struct * tty, struct inode * inode, |
inode | 52 | include/linux/ufs_fs.h | #define ufs_ino_ok(inode) ((inode->i_ino < 2) && \ |
inode | 53 | include/linux/ufs_fs.h | (inode->i_ino > (inode->i_sb->u.ufs_sb.s_ncg * inode->i_sb->u.ufs_sb.s_ipg - 1))) |
inode | 65 | include/linux/ufs_fs.h | #define ufs_ino2cg(inode) ((inode)->i_ino/(inode)->i_sb->u.ufs_sb.s_ipg) |
inode | 5 | include/linux/wrapper.h | #define inode_handle struct inode |
inode | 112 | include/linux/xd.h | static int xd_open (struct inode *inode,struct file *file); |
inode | 114 | include/linux/xd.h | static int xd_ioctl (struct inode *inode,struct file *file,unsigned int cmd,unsigned long arg); |
inode | 115 | include/linux/xd.h | static void xd_release (struct inode *inode,struct file *file); |
inode | 67 | include/linux/xia_fs.h | extern int xiafs_lookup(struct inode * dir,const char * name, int len, |
inode | 68 | include/linux/xia_fs.h | struct inode ** result); |
inode | 69 | include/linux/xia_fs.h | extern int xiafs_create(struct inode * dir,const char * name, int len, int mode, |
inode | 70 | include/linux/xia_fs.h | struct inode ** result); |
inode | 71 | include/linux/xia_fs.h | extern int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode); |
inode | 72 | include/linux/xia_fs.h | extern int xiafs_rmdir(struct inode * dir, const char * name, int len); |
inode | 73 | include/linux/xia_fs.h | extern int xiafs_unlink(struct inode * dir, const char * name, int len); |
inode | 74 | include/linux/xia_fs.h | extern int xiafs_symlink(struct inode * inode, const char * name, int len, |
inode | 76 | include/linux/xia_fs.h | extern int xiafs_link(struct inode * oldinode, struct inode * dir, |
inode | 78 | include/linux/xia_fs.h | extern int xiafs_mknod(struct inode * dir, const char * name, int len, |
inode | 80 | include/linux/xia_fs.h | extern int xiafs_rename(struct inode * old_dir, const char * old_name, |
inode | 81 | include/linux/xia_fs.h | int old_len, struct inode * new_dir, |
inode | 83 | include/linux/xia_fs.h | extern struct inode * xiafs_new_inode(struct inode * dir); |
inode | 84 | include/linux/xia_fs.h | extern void xiafs_free_inode(struct inode * inode); |
inode | 90 | include/linux/xia_fs.h | extern int xiafs_bmap(struct inode *,int); |
inode | 92 | include/linux/xia_fs.h | extern struct buffer_head * xiafs_getblk(struct inode *, int, int); |
inode | 93 | include/linux/xia_fs.h | extern struct buffer_head * xiafs_bread(struct inode *, int, int); |
inode | 95 | include/linux/xia_fs.h | extern void xiafs_truncate(struct inode *); |
inode | 99 | include/linux/xia_fs.h | extern void xiafs_read_inode(struct inode *); |
inode | 100 | include/linux/xia_fs.h | extern void xiafs_write_inode(struct inode *); |
inode | 101 | include/linux/xia_fs.h | extern void xiafs_put_inode(struct inode *); |
inode | 103 | include/linux/xia_fs.h | extern int xiafs_sync_inode(struct inode *); |
inode | 104 | include/linux/xia_fs.h | extern int xiafs_sync_file(struct inode *, struct file *); |
inode | 75 | include/net/sock.h | struct inode * inode; |
inode | 909 | init/main.c | extern struct inode *pseudo_root; |
inode | 69 | kernel/ksyms.c | extern void blkdev_release(struct inode * inode); |
inode | 328 | kernel/sys.c | struct inode *inode = (struct inode *)0; |
inode | 340 | kernel/sys.c | if (acct_file.f_inode != (struct inode *) 0) |
inode | 352 | kernel/sys.c | error = open_namei(tmp, O_RDWR, 0600, &inode, 0); |
inode | 358 | kernel/sys.c | if (!S_ISREG(inode->i_mode)) { |
inode | 359 | kernel/sys.c | iput(inode); |
inode | 363 | kernel/sys.c | if (!inode->i_op || !inode->i_op->default_file_ops || |
inode | 364 | kernel/sys.c | !inode->i_op->default_file_ops->write) { |
inode | 365 | kernel/sys.c | iput(inode); |
inode | 372 | kernel/sys.c | acct_file.f_inode = inode; |
inode | 373 | kernel/sys.c | acct_file.f_pos = inode->i_size; |
inode | 375 | kernel/sys.c | acct_file.f_op = inode->i_op->default_file_ops; |
inode | 379 | kernel/sys.c | iput(inode); |
inode | 48 | kernel/sysctl.c | static int proc_readsys(struct inode * inode, struct file * file, |
inode | 50 | kernel/sysctl.c | static int proc_writesys(struct inode * inode, struct file * file, |
inode | 52 | kernel/sysctl.c | static int proc_sys_permission(struct inode *, int); |
inode | 450 | kernel/sysctl.c | static int do_rw_proc(int write, struct inode * inode, struct file * file, |
inode | 462 | kernel/sysctl.c | de = (struct proc_dir_entry*) inode->u.generic_ip; |
inode | 479 | kernel/sysctl.c | static int proc_readsys(struct inode * inode, struct file * file, |
inode | 482 | kernel/sysctl.c | return do_rw_proc(0, inode, file, buf, count); |
inode | 485 | kernel/sysctl.c | static int proc_writesys(struct inode * inode, struct file * file, |
inode | 488 | kernel/sysctl.c | return do_rw_proc(1, inode, file, (char *) buf, count); |
inode | 491 | kernel/sysctl.c | static int proc_sys_permission(struct inode *inode, int op) |
inode | 493 | kernel/sysctl.c | return test_perm(inode->i_mode, op); |
inode | 49 | mm/filemap.c | void invalidate_inode_pages(struct inode * inode) |
inode | 54 | mm/filemap.c | p = &inode->i_pages; |
inode | 60 | mm/filemap.c | inode->i_nrpages--; |
inode | 67 | mm/filemap.c | page->inode = NULL; |
inode | 77 | mm/filemap.c | void truncate_inode_pages(struct inode * inode, unsigned long start) |
inode | 83 | mm/filemap.c | p = &inode->i_pages; |
inode | 93 | mm/filemap.c | inode->i_nrpages--; |
inode | 100 | mm/filemap.c | page->inode = NULL; |
inode | 156 | mm/filemap.c | if (page->inode) { |
inode | 199 | mm/filemap.c | if (!p->inode) |
inode | 211 | mm/filemap.c | void update_vm_cache(struct inode * inode, unsigned long pos, const char * buf, int count) |
inode | 223 | mm/filemap.c | page = find_page(inode, pos); |
inode | 241 | mm/filemap.c | struct inode * inode, unsigned long offset) |
inode | 246 | mm/filemap.c | add_page_to_inode_queue(inode, page); |
inode | 247 | mm/filemap.c | add_page_to_hash_queue(inode, page); |
inode | 255 | mm/filemap.c | static unsigned long try_to_read_ahead(struct inode * inode, unsigned long offset, unsigned long page_cache) |
inode | 265 | mm/filemap.c | if (offset >= inode->i_size) |
inode | 268 | mm/filemap.c | page = find_page(inode, offset); |
inode | 277 | mm/filemap.c | add_to_page_cache(page, inode, offset); |
inode | 278 | mm/filemap.c | inode->i_op->readpage(inode, page); |
inode | 431 | mm/filemap.c | static inline unsigned long generic_file_readahead(struct file * filp, struct inode * inode, |
inode | 450 | mm/filemap.c | if (rapos < inode->i_size) |
inode | 471 | mm/filemap.c | if (rapos < inode->i_size) |
inode | 488 | mm/filemap.c | page_cache = try_to_read_ahead(inode, rapos + ahead, page_cache); |
inode | 541 | mm/filemap.c | int generic_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 605 | mm/filemap.c | if (pos >= inode->i_size) |
inode | 612 | mm/filemap.c | page = find_page(inode, pos & PAGE_MASK); |
inode | 632 | mm/filemap.c | if (pos >= inode->i_size) |
inode | 634 | mm/filemap.c | page = find_page(inode, pos & PAGE_MASK); |
inode | 649 | mm/filemap.c | page_cache = generic_file_readahead(filp, inode, try_async, pos, page, page_cache); |
inode | 657 | mm/filemap.c | if (nr > inode->i_size - pos) |
inode | 658 | mm/filemap.c | nr = inode->i_size - pos; |
inode | 677 | mm/filemap.c | add_to_page_cache(page, inode, pos & PAGE_MASK); |
inode | 688 | mm/filemap.c | error = inode->i_op->readpage(inode, page); |
inode | 702 | mm/filemap.c | if (!IS_RDONLY(inode)) { |
inode | 703 | mm/filemap.c | inode->i_atime = CURRENT_TIME; |
inode | 704 | mm/filemap.c | inode->i_dirt = 1; |
inode | 715 | mm/filemap.c | static inline unsigned long fill_page(struct inode * inode, unsigned long offset) |
inode | 720 | mm/filemap.c | page = find_page(inode, offset); |
inode | 724 | mm/filemap.c | page = find_page(inode, offset); |
inode | 731 | mm/filemap.c | add_to_page_cache(page, inode, offset); |
inode | 732 | mm/filemap.c | inode->i_op->readpage(inode, page); |
inode | 734 | mm/filemap.c | new_page = try_to_read_ahead(inode, offset + PAGE_SIZE, 0); |
inode | 751 | mm/filemap.c | struct inode * inode = area->vm_inode; |
inode | 755 | mm/filemap.c | if (offset >= inode->i_size && (area->vm_flags & VM_SHARED) && area->vm_mm == current->mm) |
inode | 758 | mm/filemap.c | page = fill_page(inode, offset); |
inode | 776 | mm/filemap.c | static inline int do_write_page(struct inode * inode, struct file * file, |
inode | 784 | mm/filemap.c | if (S_ISREG(inode->i_mode)) { |
inode | 785 | mm/filemap.c | if (size > inode->i_size) |
inode | 786 | mm/filemap.c | size = inode->i_size; |
inode | 795 | mm/filemap.c | if (size == file->f_op->write(inode, file, (const char *) page, size)) |
inode | 807 | mm/filemap.c | struct inode * inode; |
inode | 821 | mm/filemap.c | inode = vma->vm_inode; |
inode | 822 | mm/filemap.c | file.f_op = inode->i_op->default_file_ops; |
inode | 828 | mm/filemap.c | file.f_inode = inode; |
inode | 832 | mm/filemap.c | down(&inode->i_sem); |
inode | 833 | mm/filemap.c | result = do_write_page(inode, &file, (const char *) page, offset); |
inode | 834 | mm/filemap.c | up(&inode->i_sem); |
inode | 1047 | mm/filemap.c | int generic_file_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 1059 | mm/filemap.c | if (vma->vm_offset & (inode->i_sb->s_blocksize - 1)) |
inode | 1062 | mm/filemap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 1064 | mm/filemap.c | if (!inode->i_op || !inode->i_op->readpage) |
inode | 1066 | mm/filemap.c | if (!IS_RDONLY(inode)) { |
inode | 1067 | mm/filemap.c | inode->i_atime = CURRENT_TIME; |
inode | 1068 | mm/filemap.c | inode->i_dirt = 1; |
inode | 1070 | mm/filemap.c | vma->vm_inode = inode; |
inode | 1071 | mm/filemap.c | inode->i_count++; |
inode | 815 | mm/memory.c | void vmtruncate(struct inode * inode, unsigned long offset) |
inode | 819 | mm/memory.c | truncate_inode_pages(inode, offset); |
inode | 820 | mm/memory.c | if (!inode->i_mmap) |
inode | 822 | mm/memory.c | mpnt = inode->i_mmap; |
inode | 845 | mm/memory.c | } while ((mpnt = mpnt->vm_next_share) != inode->i_mmap); |
inode | 791 | mm/mmap.c | struct inode * inode; |
inode | 819 | mm/mmap.c | inode = vmp->vm_inode; |
inode | 820 | mm/mmap.c | if (!inode) |
inode | 824 | mm/mmap.c | if ((share = inode->i_mmap)) { |
inode | 830 | mm/mmap.c | inode->i_mmap = vmp->vm_next_share = vmp->vm_prev_share = vmp; |
inode | 838 | mm/mmap.c | struct inode * inode = mpnt->vm_inode; |
inode | 840 | mm/mmap.c | if (!inode) |
inode | 844 | mm/mmap.c | if (inode->i_mmap != mpnt) |
inode | 846 | mm/mmap.c | inode->i_mmap = NULL; |
inode | 850 | mm/mmap.c | if (inode->i_mmap == mpnt) |
inode | 851 | mm/mmap.c | inode->i_mmap = mpnt->vm_next_share; |
inode | 94 | mm/page_io.c | struct inode *swapf = p->swap_file; |
inode | 317 | mm/swapfile.c | struct inode * inode; |
inode | 323 | mm/swapfile.c | i = namei(specialfile,&inode); |
inode | 331 | mm/swapfile.c | if (p->swap_file == inode) |
inode | 334 | mm/swapfile.c | if (S_ISBLK(inode->i_mode) |
inode | 335 | mm/swapfile.c | && (p->swap_device == inode->i_rdev)) |
inode | 342 | mm/swapfile.c | iput(inode); |
inode | 357 | mm/swapfile.c | iput(inode); |
inode | 364 | mm/swapfile.c | filp.f_inode = inode; |
inode | 367 | mm/swapfile.c | if( !blkdev_open(inode, &filp) && |
inode | 369 | mm/swapfile.c | filp.f_op->release(inode,&filp); |
inode | 370 | mm/swapfile.c | filp.f_op->release(inode,&filp); |
inode | 373 | mm/swapfile.c | iput(inode); |
inode | 395 | mm/swapfile.c | struct inode * swap_inode; |
inode | 70 | net/netlink.c | static int netlink_write(struct inode * inode, struct file * file, const char * buf, int count) |
inode | 72 | net/netlink.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 84 | net/netlink.c | static int netlink_read(struct inode * inode, struct file * file, char * buf, int count) |
inode | 86 | net/netlink.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 112 | net/netlink.c | static int netlink_lseek(struct inode * inode, struct file * file, |
inode | 118 | net/netlink.c | static int netlink_open(struct inode * inode, struct file * file) |
inode | 120 | net/netlink.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 135 | net/netlink.c | static void netlink_release(struct inode * inode, struct file * file) |
inode | 137 | net/netlink.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 143 | net/netlink.c | static int netlink_ioctl(struct inode *inode, struct file *file, |
inode | 146 | net/netlink.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 83 | net/socket.c | static int sock_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 85 | net/socket.c | static int sock_read(struct inode *inode, struct file *file, char *buf, |
inode | 87 | net/socket.c | static int sock_write(struct inode *inode, struct file *file, const char *buf, |
inode | 90 | net/socket.c | static void sock_close(struct inode *inode, struct file *file); |
inode | 91 | net/socket.c | static int sock_select(struct inode *inode, struct file *file, int which, select_table *seltable); |
inode | 92 | net/socket.c | static int sock_ioctl(struct inode *inode, struct file *file, |
inode | 94 | net/socket.c | static int sock_fasync(struct inode *inode, struct file *filp, int on); |
inode | 172 | net/socket.c | static int get_fd(struct inode *inode) |
inode | 200 | net/socket.c | file->f_inode = inode; |
inode | 201 | net/socket.c | if (inode) |
inode | 202 | net/socket.c | inode->i_count++; |
inode | 215 | net/socket.c | __inline struct socket *socki_lookup(struct inode *inode) |
inode | 217 | net/socket.c | return &inode->u.socket_i; |
inode | 227 | net/socket.c | struct inode *inode; |
inode | 232 | net/socket.c | inode = file->f_inode; |
inode | 233 | net/socket.c | if (!inode || !inode->i_sock) |
inode | 239 | net/socket.c | return socki_lookup(inode); |
inode | 248 | net/socket.c | struct inode * inode; |
inode | 251 | net/socket.c | inode = get_empty_inode(); |
inode | 252 | net/socket.c | if (!inode) |
inode | 255 | net/socket.c | inode->i_mode = S_IFSOCK; |
inode | 256 | net/socket.c | inode->i_sock = 1; |
inode | 257 | net/socket.c | inode->i_uid = current->uid; |
inode | 258 | net/socket.c | inode->i_gid = current->gid; |
inode | 260 | net/socket.c | sock = &inode->u.socket_i; |
inode | 269 | net/socket.c | sock->wait = &inode->i_wait; |
inode | 270 | net/socket.c | sock->inode = inode; /* "backlink": we could use pointer arithmetic instead */ |
inode | 324 | net/socket.c | static int sock_lseek(struct inode *inode, struct file *file, off_t offset, int whence) |
inode | 334 | net/socket.c | static int sock_read(struct inode *inode, struct file *file, char *ubuf, int size) |
inode | 341 | net/socket.c | sock = socki_lookup(inode); |
inode | 366 | net/socket.c | static int sock_write(struct inode *inode, struct file *file, const char *ubuf, int size) |
inode | 373 | net/socket.c | sock = socki_lookup(inode); |
inode | 401 | net/socket.c | int sock_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 405 | net/socket.c | sock = socki_lookup(inode); |
inode | 410 | net/socket.c | static int sock_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 414 | net/socket.c | sock = socki_lookup(inode); |
inode | 426 | net/socket.c | void sock_close(struct inode *inode, struct file *filp) |
inode | 432 | net/socket.c | if (!inode) |
inode | 434 | net/socket.c | sock_fasync(inode, filp, 0); |
inode | 435 | net/socket.c | sock_release(socki_lookup(inode)); |
inode | 442 | net/socket.c | static int sock_fasync(struct inode *inode, struct file *filp, int on) |
inode | 455 | net/socket.c | sock = socki_lookup(inode); |
inode | 122 | net/unix/af_unix.c | static unix_socket *unix_find_socket(struct inode *i) |
inode | 129 | net/unix/af_unix.c | if(s->protinfo.af_unix.inode==i) |
inode | 195 | net/unix/af_unix.c | if(sk->protinfo.af_unix.inode!=NULL) |
inode | 197 | net/unix/af_unix.c | iput(sk->protinfo.af_unix.inode); |
inode | 198 | net/unix/af_unix.c | sk->protinfo.af_unix.inode=NULL; |
inode | 309 | net/unix/af_unix.c | sk->protinfo.af_unix.inode=NULL; |
inode | 370 | net/unix/af_unix.c | struct inode *inode; |
inode | 375 | net/unix/af_unix.c | err = open_namei(path, 2, S_IFSOCK, &inode, NULL); |
inode | 382 | net/unix/af_unix.c | u=unix_find_socket(inode); |
inode | 383 | net/unix/af_unix.c | iput(inode); |
inode | 409 | net/unix/af_unix.c | if(sk->protinfo.af_unix.inode!=NULL) |
inode | 422 | net/unix/af_unix.c | err=open_namei(sk->protinfo.af_unix.name, 2, S_IFSOCK, &sk->protinfo.af_unix.inode, NULL); |
inode | 1256 | net/unix/af_unix.c | s->socket->inode ? s->socket->inode->i_ino : 0); |