tag | line | file | source code |
inode | 190 | arch/i386/ibcs/binfmt_coff.c | if (!bprm->inode->i_op || |
inode | 191 | arch/i386/ibcs/binfmt_coff.c | !bprm->inode->i_op->default_file_ops->mmap) { |
inode | 218 | arch/i386/ibcs/binfmt_coff.c | status = read_exec (bprm->inode, /* INODE for file */ |
inode | 379 | arch/i386/ibcs/binfmt_coff.c | fd = open_inode (bprm->inode, O_RDONLY); |
inode | 467 | arch/i386/ibcs/binfmt_coff.c | current->executable = bprm->inode; /* Store inode for file */ |
inode | 468 | arch/i386/ibcs/binfmt_coff.c | ++bprm->inode->i_count; /* Count the open inode */ |
inode | 656 | arch/i386/ibcs/binfmt_coff.c | status = read_exec (exe_bprm->inode, /* INODE for file */ |
inode | 760 | arch/i386/ibcs/binfmt_coff.c | bprm->inode = file->f_inode; /* The only item _really_ needed */ |
inode | 766 | arch/i386/ibcs/binfmt_coff.c | status = read_exec (bprm->inode, /* INODE for file */ |
inode | 128 | arch/i386/ibcs/binfmt_elf.c | struct inode * interpreter_inode) |
inode | 216 | arch/i386/ibcs/binfmt_elf.c | struct inode * interpreter_inode) |
inode | 268 | arch/i386/ibcs/binfmt_elf.c | struct inode *interpreter_inode; |
inode | 297 | arch/i386/ibcs/binfmt_elf.c | (!bprm->inode->i_op || !bprm->inode->i_op->default_file_ops || |
inode | 298 | arch/i386/ibcs/binfmt_elf.c | !bprm->inode->i_op->default_file_ops->mmap)){ |
inode | 309 | arch/i386/ibcs/binfmt_elf.c | retval = read_exec(bprm->inode, elf_ex.e_phoff, (char *) elf_phdata, |
inode | 322 | arch/i386/ibcs/binfmt_elf.c | elf_exec_fileno = open_inode(bprm->inode, O_RDONLY); |
inode | 348 | arch/i386/ibcs/binfmt_elf.c | retval = read_exec(bprm->inode,elf_ppnt->p_offset,elf_interpreter, |
inode | 518 | arch/i386/ibcs/binfmt_elf.c | current->executable = bprm->inode; |
inode | 519 | arch/i386/ibcs/binfmt_elf.c | bprm->inode->i_count++; |
inode | 569 | arch/i386/ibcs/binfmt_elf.c | struct inode * inode; |
inode | 579 | arch/i386/ibcs/binfmt_elf.c | inode = file->f_inode; |
inode | 583 | arch/i386/ibcs/binfmt_elf.c | if (file->f_op->read(inode, file, (char *) &elf_ex, sizeof(elf_ex)) != sizeof(elf_ex)) { |
inode | 596 | arch/i386/ibcs/binfmt_elf.c | (!inode->i_op || |
inode | 597 | arch/i386/ibcs/binfmt_elf.c | !inode->i_op->default_file_ops->mmap)){ |
inode | 611 | arch/i386/ibcs/binfmt_elf.c | retval = read_exec(inode, elf_ex.e_phoff, (char *) elf_phdata, |
inode | 455 | drivers/block/aztcd.c | static int aztcd_ioctl(struct inode *ip, struct file *fp, unsigned int cmd, unsigned long arg) |
inode | 1179 | drivers/block/aztcd.c | int aztcd_open(struct inode *ip, struct file *fp) |
inode | 1217 | drivers/block/aztcd.c | static void aztcd_release(struct inode * inode, struct file * file) |
inode | 1221 | drivers/block/aztcd.c | printk("inode: %p, inode->i_rdev: %x file: %p\n",inode,inode->i_rdev,file); |
inode | 1225 | drivers/block/aztcd.c | sync_dev(inode->i_rdev); /*??? isn't it a read only dev?*/ |
inode | 1226 | drivers/block/aztcd.c | invalidate_buffers(inode -> i_rdev); |
inode | 223 | drivers/block/cdu31a.c | static int scd_open(struct inode *inode, struct file *filp); |
inode | 1396 | drivers/block/cdu31a.c | struct inode in; |
inode | 1987 | drivers/block/cdu31a.c | struct inode *inode) |
inode | 2014 | drivers/block/cdu31a.c | scd_open (inode, NULL); |
inode | 2171 | drivers/block/cdu31a.c | scd_ioctl(struct inode *inode, |
inode | 2182 | drivers/block/cdu31a.c | if (!inode) |
inode | 2524 | drivers/block/cdu31a.c | return(read_audio(&ra, inode)); |
inode | 2540 | drivers/block/cdu31a.c | scd_open(struct inode *inode, |
inode | 2644 | drivers/block/cdu31a.c | check_disk_change(inode->i_rdev); |
inode | 2658 | drivers/block/cdu31a.c | scd_release(struct inode *inode, |
inode | 2671 | drivers/block/cdu31a.c | sync_dev(inode->i_rdev); |
inode | 2709 | drivers/block/floppy.c | static int fd_ioctl(struct inode *inode, struct file *filp, unsigned int cmd, |
inode | 2722 | drivers/block/floppy.c | device = inode->i_rdev; |
inode | 2935 | drivers/block/floppy.c | static int floppy_read(struct inode * inode, struct file * filp, |
inode | 2938 | drivers/block/floppy.c | int drive = DRIVE(inode->i_rdev); |
inode | 2940 | drivers/block/floppy.c | check_disk_change(inode->i_rdev); |
inode | 2943 | drivers/block/floppy.c | return block_read(inode, filp, buf, count); |
inode | 2946 | drivers/block/floppy.c | static int floppy_write(struct inode * inode, struct file * filp, |
inode | 2951 | drivers/block/floppy.c | int drive = DRIVE(inode->i_rdev); |
inode | 2955 | drivers/block/floppy.c | check_disk_change(inode->i_rdev); |
inode | 2963 | drivers/block/floppy.c | ret= block_write(inode, filp, buf, count); |
inode | 2967 | drivers/block/floppy.c | static void floppy_release(struct inode * inode, struct file * filp) |
inode | 2971 | drivers/block/floppy.c | drive = DRIVE(inode->i_rdev); |
inode | 2976 | drivers/block/floppy.c | block_fsync(inode,filp); |
inode | 2993 | drivers/block/floppy.c | do{floppy_release(inode,filp); \ |
inode | 2996 | drivers/block/floppy.c | static int floppy_open(struct inode * inode, struct file * filp) |
inode | 3006 | drivers/block/floppy.c | drive = DRIVE(inode->i_rdev); |
inode | 3012 | drivers/block/floppy.c | if (TYPE(inode->i_rdev) >= NUMBER(floppy_type)) |
inode | 3015 | drivers/block/floppy.c | if (UDRS->fd_ref && old_dev != inode->i_rdev) |
inode | 3035 | drivers/block/floppy.c | UDRS->fd_device = inode->i_rdev; |
inode | 3037 | drivers/block/floppy.c | if (old_dev && old_dev != inode->i_rdev) { |
inode | 3044 | drivers/block/floppy.c | if ((filp->f_mode & 2) || (permission(inode,2) == 0)) |
inode | 3056 | drivers/block/floppy.c | check_disk_change(inode->i_rdev); |
inode | 779 | drivers/block/hd.c | static int hd_ioctl(struct inode * inode, struct file * file, |
inode | 786 | drivers/block/hd.c | if ((!inode) || (!inode->i_rdev)) |
inode | 788 | drivers/block/hd.c | dev = DEVICE_NR(inode->i_rdev); |
inode | 803 | drivers/block/hd.c | put_fs_long(hd[MINOR(inode->i_rdev)].start_sect, |
inode | 809 | drivers/block/hd.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 816 | drivers/block/hd.c | put_fs_long(read_ahead[MAJOR(inode->i_rdev)],(long *) arg); |
inode | 823 | drivers/block/hd.c | put_fs_long(hd[MINOR(inode->i_rdev)].nr_sects, (long *) arg); |
inode | 827 | drivers/block/hd.c | fsync_dev(inode->i_rdev); |
inode | 828 | drivers/block/hd.c | invalidate_buffers(inode->i_rdev); |
inode | 832 | drivers/block/hd.c | return revalidate_hddisk(inode->i_rdev, 1); |
inode | 836 | drivers/block/hd.c | if ((arg > 1) || (MINOR(inode->i_rdev) & 0x3F)) |
inode | 859 | drivers/block/hd.c | if (MINOR(inode->i_rdev) & 0x3F) return -EINVAL; |
inode | 877 | drivers/block/hd.c | if (MINOR(inode->i_rdev) & 0x3F) return -EINVAL; |
inode | 885 | drivers/block/hd.c | RO_IOCTLS(inode->i_rdev,arg); |
inode | 891 | drivers/block/hd.c | static int hd_open(struct inode * inode, struct file * filp) |
inode | 894 | drivers/block/hd.c | target = DEVICE_NR(inode->i_rdev); |
inode | 906 | drivers/block/hd.c | static void hd_release(struct inode * inode, struct file * file) |
inode | 909 | drivers/block/hd.c | sync_dev(inode->i_rdev); |
inode | 911 | drivers/block/hd.c | target = DEVICE_NR(inode->i_rdev); |
inode | 1314 | drivers/block/ide-cd.c | static int ide_cdrom_ioctl (ide_dev_t *dev, struct inode *inode, |
inode | 1568 | drivers/block/ide-cd.c | cdrom_open (struct inode *ip, struct file *fp, ide_dev_t *dev) |
inode | 1589 | drivers/block/ide-cd.c | cdrom_release (struct inode *inode, struct file *file, ide_dev_t *dev) |
inode | 1593 | drivers/block/ide-cd.c | invalidate_buffers (inode->i_rdev); |
inode | 1252 | drivers/block/ide.c | static int ide_open(struct inode * inode, struct file * filp) |
inode | 1257 | drivers/block/ide.c | if ((dev = get_info_ptr(inode->i_rdev)) == NULL) |
inode | 1267 | drivers/block/ide.c | return cdrom_open (inode, filp, dev); |
inode | 1276 | drivers/block/ide.c | static void ide_release(struct inode * inode, struct file * file) |
inode | 1280 | drivers/block/ide.c | if ((dev = get_info_ptr(inode->i_rdev)) != NULL) { |
inode | 1281 | drivers/block/ide.c | sync_dev(inode->i_rdev); |
inode | 1285 | drivers/block/ide.c | cdrom_release (inode, file, dev); |
inode | 1397 | drivers/block/ide.c | static int ide_ioctl (struct inode *inode, struct file *file, |
inode | 1405 | drivers/block/ide.c | if (!inode || !inode->i_rdev) |
inode | 1407 | drivers/block/ide.c | if ((dev = get_info_ptr(inode->i_rdev)) == NULL) |
inode | 1420 | drivers/block/ide.c | put_fs_long((unsigned)ide_hd[DEV_HWIF][MINOR(inode->i_rdev)].start_sect, |
inode | 1426 | drivers/block/ide.c | fsync_dev(inode->i_rdev); |
inode | 1427 | drivers/block/ide.c | invalidate_buffers(inode->i_rdev); |
inode | 1433 | drivers/block/ide.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 1437 | drivers/block/ide.c | return write_fs_long(arg, read_ahead[MAJOR(inode->i_rdev)]); |
inode | 1440 | drivers/block/ide.c | return write_fs_long(arg, ide_hd[DEV_HWIF][MINOR(inode->i_rdev)].nr_sects); |
inode | 1442 | drivers/block/ide.c | return revalidate_disk(inode->i_rdev); |
inode | 1454 | drivers/block/ide.c | if (!arg || (MINOR(inode->i_rdev) & PARTN_MASK)) |
inode | 1465 | drivers/block/ide.c | if ((arg > 1) || (MINOR(inode->i_rdev) & PARTN_MASK)) |
inode | 1475 | drivers/block/ide.c | if ((arg > 1) || (MINOR(inode->i_rdev) & PARTN_MASK)) |
inode | 1485 | drivers/block/ide.c | if (MINOR(inode->i_rdev) & PARTN_MASK) |
inode | 1499 | drivers/block/ide.c | do_drive_cmd (inode->i_rdev, NULL); |
inode | 1511 | drivers/block/ide.c | err = do_drive_cmd(inode->i_rdev,NULL); |
inode | 1516 | drivers/block/ide.c | err = do_drive_cmd(inode->i_rdev,(char *)&args); |
inode | 1524 | drivers/block/ide.c | RO_IOCTLS(inode->i_rdev, arg); |
inode | 1529 | drivers/block/ide.c | return ide_cdrom_ioctl(dev, inode, file, cmd, arg); |
inode | 240 | drivers/block/mcd.c | mcd_ioctl(struct inode *ip, struct file *fp, unsigned int cmd, |
inode | 1013 | drivers/block/mcd.c | mcd_open(struct inode *ip, struct file *fp) |
inode | 1052 | drivers/block/mcd.c | mcd_release(struct inode * inode, struct file * file) |
inode | 1056 | drivers/block/mcd.c | sync_dev(inode->i_rdev); |
inode | 1057 | drivers/block/mcd.c | invalidate_buffers(inode -> i_rdev); |
inode | 207 | drivers/block/ramdisk.c | struct inode inode; |
inode | 225 | drivers/block/ramdisk.c | memset(&inode, 0, sizeof(inode)); |
inode | 226 | drivers/block/ramdisk.c | inode.i_rdev = ROOT_DEV; |
inode | 228 | drivers/block/ramdisk.c | filp.f_inode = &inode; |
inode | 229 | drivers/block/ramdisk.c | if(blkdev_open(&inode, &filp) == 0 ){ |
inode | 232 | drivers/block/ramdisk.c | filp.f_op->release(&inode,&filp); |
inode | 3210 | drivers/block/sbpcd.c | static int sbpcd_ioctl(struct inode *inode, struct file *file, u_int cmd, |
inode | 3216 | drivers/block/sbpcd.c | MINOR(inode->i_rdev), cmd, arg)); |
inode | 3217 | drivers/block/sbpcd.c | if (!inode) return (-EINVAL); |
inode | 3218 | drivers/block/sbpcd.c | i=MINOR(inode->i_rdev); |
inode | 3221 | drivers/block/sbpcd.c | printk("SBPCD: ioctl: bad device: %04X\n", inode->i_rdev); |
inode | 3706 | drivers/block/sbpcd.c | if(!inode->i_rdev) return -EINVAL; |
inode | 3708 | drivers/block/sbpcd.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 4103 | drivers/block/sbpcd.c | static int sbpcd_open(struct inode *ip, struct file *fp) |
inode | 4174 | drivers/block/sbpcd.c | static void sbpcd_release(struct inode * ip, struct file * file) |
inode | 190 | drivers/block/sonycd535.c | static int cdu_open(struct inode *inode, struct file *filp); |
inode | 1074 | drivers/block/sonycd535.c | cdu_ioctl(struct inode *inode, |
inode | 1085 | drivers/block/sonycd535.c | if (!inode) { |
inode | 1088 | drivers/block/sonycd535.c | dev = MINOR(inode->i_rdev) >> 6; |
inode | 1381 | drivers/block/sonycd535.c | cdu_open(struct inode *inode, |
inode | 1409 | drivers/block/sonycd535.c | if (inode) { |
inode | 1410 | drivers/block/sonycd535.c | check_disk_change(inode->i_rdev); |
inode | 1429 | drivers/block/sonycd535.c | cdu_release(struct inode *inode, |
inode | 1441 | drivers/block/sonycd535.c | sync_dev(inode->i_rdev); |
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(MINOR(inode->i_rdev)); |
inode | 238 | drivers/block/xd.c | static int xd_ioctl (struct inode *inode,struct file *file,u_int cmd,u_long arg) |
inode | 241 | drivers/block/xd.c | int dev = DEVICE_NR(MINOR(inode->i_rdev)),err; |
inode | 243 | drivers/block/xd.c | if (inode && (dev < xd_drives)) |
inode | 252 | drivers/block/xd.c | put_fs_long(xd[MINOR(inode->i_rdev)].start_sect,(long *) &geometry->start); |
inode | 259 | drivers/block/xd.c | if(!inode->i_rdev) return -EINVAL; |
inode | 261 | drivers/block/xd.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 267 | drivers/block/xd.c | put_fs_long(xd[MINOR(inode->i_rdev)].nr_sects,(long *) arg); |
inode | 274 | drivers/block/xd.c | if(!inode->i_rdev) return -EINVAL; |
inode | 275 | drivers/block/xd.c | fsync_dev(inode->i_rdev); |
inode | 276 | drivers/block/xd.c | invalidate_buffers(inode->i_rdev); |
inode | 280 | drivers/block/xd.c | return (xd_reread_partitions(inode->i_rdev)); |
inode | 281 | drivers/block/xd.c | RO_IOCTLS(inode->i_rdev,arg); |
inode | 287 | drivers/block/xd.c | static void xd_release (struct inode *inode, struct file *file) |
inode | 289 | drivers/block/xd.c | int dev = DEVICE_NR(MINOR(inode->i_rdev)); |
inode | 87 | drivers/char/atixlmouse.c | static void release_mouse(struct inode * inode, struct file * file) |
inode | 96 | drivers/char/atixlmouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 116 | drivers/char/atixlmouse.c | static int write_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 121 | drivers/char/atixlmouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 152 | drivers/char/atixlmouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 93 | drivers/char/busmouse.c | static void close_mouse(struct inode * inode, struct file * file) |
inode | 106 | drivers/char/busmouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 127 | drivers/char/busmouse.c | static int write_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 136 | drivers/char/busmouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 189 | drivers/char/busmouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 169 | drivers/char/lp.c | static int lp_write_interrupt(struct inode * inode, struct file * file, char * buf, int count) |
inode | 171 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 234 | drivers/char/lp.c | static int lp_write_polled(struct inode * inode, struct file * file, |
inode | 238 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 308 | drivers/char/lp.c | static int lp_write(struct inode * inode, struct file * file, char * buf, int count) |
inode | 310 | drivers/char/lp.c | if (LP_IRQ(MINOR(inode->i_rdev))) |
inode | 311 | drivers/char/lp.c | return lp_write_interrupt(inode, file, buf, count); |
inode | 313 | drivers/char/lp.c | return lp_write_polled(inode, file, buf, count); |
inode | 316 | drivers/char/lp.c | static int lp_lseek(struct inode * inode, struct file * file, |
inode | 322 | drivers/char/lp.c | static int lp_open(struct inode * inode, struct file * file) |
inode | 324 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 380 | drivers/char/lp.c | static void lp_release(struct inode * inode, struct file * file) |
inode | 382 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 396 | drivers/char/lp.c | static int lp_ioctl(struct inode *inode, struct file *file, |
inode | 399 | drivers/char/lp.c | unsigned int minor = MINOR(inode->i_rdev); |
inode | 28 | drivers/char/mem.c | static int read_ram(struct inode * inode, struct file * file,char * buf, int count) |
inode | 33 | drivers/char/mem.c | static int write_ram(struct inode * inode, struct file * file,char * buf, int count) |
inode | 38 | drivers/char/mem.c | static int read_mem(struct inode * inode, struct file * file,char * buf, int count) |
inode | 63 | drivers/char/mem.c | static int write_mem(struct inode * inode, struct file * file,char * buf, int count) |
inode | 88 | drivers/char/mem.c | static int mmap_mem(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 104 | drivers/char/mem.c | vma->vm_inode = inode; |
inode | 105 | drivers/char/mem.c | inode->i_count++; |
inode | 109 | drivers/char/mem.c | static int read_kmem(struct inode *inode, struct file *file, char *buf, int count) |
inode | 113 | drivers/char/mem.c | read1 = read_mem(inode, file, buf, count); |
inode | 123 | drivers/char/mem.c | static int read_port(struct inode * inode,struct file * file,char * buf, int count) |
inode | 137 | drivers/char/mem.c | static int write_port(struct inode * inode,struct file * file,char * buf, int count) |
inode | 151 | drivers/char/mem.c | static int read_null(struct inode * node,struct file * file,char * buf,int count) |
inode | 156 | drivers/char/mem.c | static int write_null(struct inode * inode,struct file * file,char * buf, int count) |
inode | 161 | drivers/char/mem.c | static int read_zero(struct inode * node,struct file * file,char * buf,int count) |
inode | 172 | drivers/char/mem.c | static int mmap_zero(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 181 | drivers/char/mem.c | static int read_full(struct inode * node,struct file * file,char * buf,int count) |
inode | 186 | drivers/char/mem.c | static int write_full(struct inode * inode,struct file * file,char * buf, int count) |
inode | 196 | drivers/char/mem.c | static int null_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 208 | drivers/char/mem.c | static int memory_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 319 | drivers/char/mem.c | static int memory_open(struct inode * inode, struct file * filp) |
inode | 321 | drivers/char/mem.c | switch (MINOR(inode->i_rdev)) { |
inode | 347 | drivers/char/mem.c | return filp->f_op->open(inode,filp); |
inode | 38 | drivers/char/mouse.c | static int mouse_open(struct inode * inode, struct file * file) |
inode | 40 | drivers/char/mouse.c | int minor = MINOR(inode->i_rdev); |
inode | 66 | drivers/char/mouse.c | return file->f_op->open(inode,file); |
inode | 73 | drivers/char/msbusmouse.c | static void release_mouse(struct inode * inode, struct file * file) |
inode | 80 | drivers/char/msbusmouse.c | static int open_mouse(struct inode * inode, struct file * file) |
inode | 99 | drivers/char/msbusmouse.c | static int write_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 104 | drivers/char/msbusmouse.c | static int read_mouse(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 125 | drivers/char/msbusmouse.c | static int mouse_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 968 | drivers/char/n_tty.c | static int normal_select(struct tty_struct * tty, struct inode * inode, |
inode | 233 | drivers/char/psaux.c | static void release_aux(struct inode * inode, struct file * file) |
inode | 245 | drivers/char/psaux.c | static void release_qp(struct inode * inode, struct file * file) |
inode | 265 | drivers/char/psaux.c | static int open_aux(struct inode * inode, struct file * file) |
inode | 295 | drivers/char/psaux.c | static int open_qp(struct inode * inode, struct file * file) |
inode | 335 | drivers/char/psaux.c | static int write_aux(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 347 | drivers/char/psaux.c | inode->i_mtime = CURRENT_TIME; |
inode | 357 | drivers/char/psaux.c | static int write_qp(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 366 | drivers/char/psaux.c | inode->i_mtime = CURRENT_TIME; |
inode | 376 | drivers/char/psaux.c | static int read_aux(struct inode * inode, struct file * file, char * buffer, int count) |
inode | 402 | drivers/char/psaux.c | inode->i_atime = CURRENT_TIME; |
inode | 411 | drivers/char/psaux.c | static int aux_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 1880 | drivers/char/tpqic02.c | static int qic02_tape_lseek(struct inode * inode, struct file * file, off_t offset, int origin) |
inode | 1918 | drivers/char/tpqic02.c | static int qic02_tape_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 1921 | drivers/char/tpqic02.c | dev_t dev = inode->i_rdev; |
inode | 2093 | drivers/char/tpqic02.c | static int qic02_tape_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 2096 | drivers/char/tpqic02.c | dev_t dev = inode->i_rdev; |
inode | 2245 | drivers/char/tpqic02.c | static int qic02_tape_open(struct inode * inode, struct file * filp) |
inode | 2247 | drivers/char/tpqic02.c | dev_t dev = inode->i_rdev; |
inode | 2431 | drivers/char/tpqic02.c | static int qic02_tape_readdir(struct inode * inode, struct file * filp, struct dirent * dp, int count) |
inode | 2438 | drivers/char/tpqic02.c | static void qic02_tape_release(struct inode * inode, struct file * filp) |
inode | 2440 | drivers/char/tpqic02.c | dev_t dev = inode->i_rdev; |
inode | 2559 | drivers/char/tpqic02.c | static int qic02_tape_ioctl(struct inode * inode, struct file * filp, |
inode | 2564 | drivers/char/tpqic02.c | int dev_maj = MAJOR(inode->i_rdev); |
inode | 2575 | drivers/char/tpqic02.c | if (!inode || !ioarg) |
inode | 94 | drivers/char/tty_io.c | static int tty_read(struct inode *, struct file *, char *, int); |
inode | 95 | drivers/char/tty_io.c | static int tty_write(struct inode *, struct file *, char *, int); |
inode | 96 | drivers/char/tty_io.c | static int tty_select(struct inode *, struct file *, int, select_table *); |
inode | 97 | drivers/char/tty_io.c | static int tty_open(struct inode *, struct file *); |
inode | 98 | drivers/char/tty_io.c | static void tty_release(struct inode *, struct file *); |
inode | 99 | drivers/char/tty_io.c | static int tty_ioctl(struct inode * inode, struct file * file, |
inode | 101 | drivers/char/tty_io.c | static int tty_fasync(struct inode * inode, struct file * filp, int on); |
inode | 283 | drivers/char/tty_io.c | static int hung_up_tty_read(struct inode * inode, struct file * file, char * buf, int count) |
inode | 288 | drivers/char/tty_io.c | static int hung_up_tty_write(struct inode * inode, struct file * file, char * buf, int count) |
inode | 293 | drivers/char/tty_io.c | static int hung_up_tty_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 298 | drivers/char/tty_io.c | static int hung_up_tty_ioctl(struct inode * inode, struct file * file, |
inode | 304 | drivers/char/tty_io.c | static int tty_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 674 | drivers/char/tty_io.c | static int tty_read(struct inode * inode, struct file * file, char * buf, int count) |
inode | 680 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_read")) |
inode | 690 | drivers/char/tty_io.c | if ((inode->i_rdev != CONSOLE_DEV) && /* don't stop on /dev/console */ |
inode | 707 | drivers/char/tty_io.c | inode->i_atime = CURRENT_TIME; |
inode | 711 | drivers/char/tty_io.c | static int tty_write(struct inode * inode, struct file * file, char * buf, int count) |
inode | 716 | drivers/char/tty_io.c | is_console = (inode->i_rdev == CONSOLE_DEV); |
inode | 722 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_write")) |
inode | 743 | drivers/char/tty_io.c | inode->i_mtime = CURRENT_TIME; |
inode | 1106 | drivers/char/tty_io.c | static int tty_open(struct inode * inode, struct file * filp) |
inode | 1115 | drivers/char/tty_io.c | device = inode->i_rdev; |
inode | 1181 | drivers/char/tty_io.c | static void tty_release(struct inode * inode, struct file * filp) |
inode | 1186 | drivers/char/tty_io.c | static int tty_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 1191 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_select")) |
inode | 1195 | drivers/char/tty_io.c | return (tty->ldisc.select)(tty, inode, filp, sel_type, wait); |
inode | 1199 | drivers/char/tty_io.c | static int tty_fasync(struct inode * inode, struct file * filp, int on) |
inode | 1205 | drivers/char/tty_io.c | if (tty_paranoia_check(tty, inode->i_rdev, "tty_fasync")) |
inode | 1279 | drivers/char/tty_io.c | static int tty_ioctl(struct inode * inode, struct file * file, |
inode | 1291 | 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, 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 | 148 | drivers/net/ppp.c | static int ppp_select(struct tty_struct *tty, struct inode * inode, |
inode | 1624 | drivers/net/ppp.c | ppp_select (struct tty_struct *tty, struct inode * inode, |
inode | 2063 | drivers/scsi/53c7,8xx.c | static struct Scsi_Host * inode_to_host (struct inode *inode) {$ |
inode | 2066 | drivers/scsi/53c7,8xx.c | for (dev = MINOR(inode->rdev), host = first_host; |
inode | 2073 | drivers/scsi/53c7,8xx.c | static debugger_user_write (struct inode *inode,struct file *filp, |
inode | 2082 | drivers/scsi/53c7,8xx.c | if (!(host = inode_to_host(inode))) |
inode | 2125 | drivers/scsi/53c7,8xx.c | static debugger_user_read (struct inode *inode,struct file *filp, |
inode | 61 | drivers/scsi/sd.c | extern int sd_ioctl(struct inode *, struct file *, unsigned int, unsigned long); |
inode | 81 | drivers/scsi/sd.c | static int sd_open(struct inode * inode, struct file * filp) |
inode | 84 | drivers/scsi/sd.c | target = DEVICE_NR(MINOR(inode->i_rdev)); |
inode | 95 | drivers/scsi/sd.c | check_disk_change(inode->i_rdev); |
inode | 98 | drivers/scsi/sd.c | sd_ioctl(inode, NULL, SCSI_IOCTL_DOORLOCK, 0); |
inode | 104 | drivers/scsi/sd.c | if(sd_sizes[MINOR(inode->i_rdev)] == 0) |
inode | 113 | drivers/scsi/sd.c | static void sd_release(struct inode * inode, struct file * file) |
inode | 116 | drivers/scsi/sd.c | sync_dev(inode->i_rdev); |
inode | 118 | drivers/scsi/sd.c | target = DEVICE_NR(MINOR(inode->i_rdev)); |
inode | 126 | drivers/scsi/sd.c | sd_ioctl(inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0); |
inode | 809 | drivers/scsi/sd.c | struct inode inode; |
inode | 822 | drivers/scsi/sd.c | inode.i_rdev = full_dev; /* This is all we really need here */ |
inode | 823 | drivers/scsi/sd.c | retval = sd_ioctl(&inode, NULL, SCSI_IOCTL_TEST_UNIT_READY, 0); |
inode | 18 | drivers/scsi/sd_ioctl.c | int sd_ioctl(struct inode * inode, struct file * file, unsigned int cmd, unsigned long arg) |
inode | 20 | drivers/scsi/sd_ioctl.c | int dev = inode->i_rdev; |
inode | 46 | drivers/scsi/sd_ioctl.c | put_fs_long(sd[MINOR(inode->i_rdev)].start_sect, |
inode | 54 | drivers/scsi/sd_ioctl.c | put_fs_long(sd[MINOR(inode->i_rdev)].nr_sects, |
inode | 59 | drivers/scsi/sd_ioctl.c | if(!inode->i_rdev) return -EINVAL; |
inode | 61 | drivers/scsi/sd_ioctl.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 65 | drivers/scsi/sd_ioctl.c | if(!inode->i_rdev) return -EINVAL; |
inode | 66 | drivers/scsi/sd_ioctl.c | fsync_dev(inode->i_rdev); |
inode | 67 | drivers/scsi/sd_ioctl.c | invalidate_buffers(inode->i_rdev); |
inode | 65 | drivers/scsi/sg.c | static int sg_ioctl(struct inode * inode,struct file * file, |
inode | 68 | drivers/scsi/sg.c | int dev = MINOR(inode->i_rdev); |
inode | 83 | drivers/scsi/sg.c | static int sg_open(struct inode * inode, struct file * filp) |
inode | 85 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 127 | drivers/scsi/sg.c | static void sg_close(struct inode * inode, struct file * filp) |
inode | 129 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 170 | drivers/scsi/sg.c | static int sg_read(struct inode *inode,struct file *filp,char *buf,int count) |
inode | 172 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 228 | drivers/scsi/sg.c | static int sg_write(struct inode *inode,struct file *filp,char *buf,int count) |
inode | 230 | drivers/scsi/sg.c | int dev=MINOR(inode->i_rdev); |
inode | 56 | drivers/scsi/sr.c | static int sr_open(struct inode *, struct file *); |
inode | 59 | drivers/scsi/sr.c | extern int sr_ioctl(struct inode *, struct file *, unsigned int, unsigned long); |
inode | 64 | drivers/scsi/sr.c | static void sr_release(struct inode * inode, struct file * file) |
inode | 66 | drivers/scsi/sr.c | sync_dev(inode->i_rdev); |
inode | 67 | drivers/scsi/sr.c | if(! --scsi_CDs[MINOR(inode->i_rdev)].device->access_count) |
inode | 68 | drivers/scsi/sr.c | sr_ioctl(inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0); |
inode | 69 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count) |
inode | 70 | drivers/scsi/sr.c | (*scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count)--; |
inode | 102 | drivers/scsi/sr.c | struct inode inode; |
inode | 112 | drivers/scsi/sr.c | inode.i_rdev = full_dev; /* This is all we really need here */ |
inode | 113 | drivers/scsi/sr.c | retval = sr_ioctl(&inode, NULL, SCSI_IOCTL_TEST_UNIT_READY, 0); |
inode | 301 | drivers/scsi/sr.c | static void sr_photocd(struct inode *inode) |
inode | 310 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].xa_flags & 0x02) { |
inode | 324 | drivers/scsi/sr.c | if (1 == scsi_CDs[MINOR(inode->i_rdev)].device->access_count) { |
inode | 325 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].mpcd_sector = 0; |
inode | 326 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags &= ~0x01; |
inode | 336 | drivers/scsi/sr.c | switch(scsi_CDs[MINOR(inode->i_rdev)].device->manufacturer) { |
inode | 348 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 383 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 390 | drivers/scsi/sr.c | if (kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 420 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 445 | drivers/scsi/sr.c | rc = kernel_scsi_ioctl(scsi_CDs[MINOR(inode->i_rdev)].device, |
inode | 451 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].needs_sector_size = 1; |
inode | 462 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].mpcd_sector = sector; |
inode | 464 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags |= 0x01; |
inode | 466 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags &= ~0x01; |
inode | 468 | drivers/scsi/sr.c | scsi_CDs[MINOR(inode->i_rdev)].xa_flags |= 0x02; |
inode | 472 | drivers/scsi/sr.c | static int sr_open(struct inode * inode, struct file * filp) |
inode | 474 | drivers/scsi/sr.c | if(MINOR(inode->i_rdev) >= sr_template.nr_dev || |
inode | 475 | drivers/scsi/sr.c | !scsi_CDs[MINOR(inode->i_rdev)].device) return -ENXIO; /* No such device */ |
inode | 480 | drivers/scsi/sr.c | check_disk_change(inode->i_rdev); |
inode | 482 | drivers/scsi/sr.c | if(!scsi_CDs[MINOR(inode->i_rdev)].device->access_count++) |
inode | 483 | drivers/scsi/sr.c | sr_ioctl(inode, NULL, SCSI_IOCTL_DOORLOCK, 0); |
inode | 484 | drivers/scsi/sr.c | if (scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count) |
inode | 485 | drivers/scsi/sr.c | (*scsi_CDs[MINOR(inode->i_rdev)].device->host->hostt->usage_count)++; |
inode | 487 | drivers/scsi/sr.c | sr_photocd(inode); |
inode | 494 | drivers/scsi/sr.c | if(scsi_CDs[MINOR(inode->i_rdev)].needs_sector_size) |
inode | 495 | drivers/scsi/sr.c | get_sectorsize(MINOR(inode->i_rdev)); |
inode | 93 | drivers/scsi/sr_ioctl.c | int sr_ioctl(struct inode * inode, struct file * file, unsigned int cmd, unsigned long arg) |
inode | 97 | drivers/scsi/sr_ioctl.c | int dev = inode->i_rdev; |
inode | 265 | drivers/scsi/sr_ioctl.c | sr_ioctl (inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0); |
inode | 424 | drivers/scsi/sr_ioctl.c | if(!inode->i_rdev) return -EINVAL; |
inode | 426 | drivers/scsi/sr_ioctl.c | read_ahead[MAJOR(inode->i_rdev)] = arg; |
inode | 102 | drivers/scsi/st.c | static int st_int_ioctl(struct inode * inode,struct file * file, |
inode | 360 | drivers/scsi/st.c | flush_buffer(struct inode * inode, struct file * filp, int seek_next) |
inode | 367 | drivers/scsi/st.c | dev = MINOR(inode->i_rdev) & 127; |
inode | 396 | drivers/scsi/st.c | result = st_int_ioctl(inode, filp, MTBSR, backspace); |
inode | 405 | drivers/scsi/st.c | scsi_tape_open(struct inode * inode, struct file * filp) |
inode | 414 | drivers/scsi/st.c | dev = MINOR(inode->i_rdev) & 127; |
inode | 621 | drivers/scsi/st.c | scsi_tape_close(struct inode * inode, struct file * filp) |
inode | 630 | drivers/scsi/st.c | dev = MINOR(inode->i_rdev); |
inode | 683 | drivers/scsi/st.c | flush_buffer(inode, filp, 0); |
inode | 688 | drivers/scsi/st.c | st_int_ioctl(inode, filp, MTREW, 1); |
inode | 703 | drivers/scsi/st.c | st_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 714 | drivers/scsi/st.c | dev = MINOR(inode->i_rdev) & 127; |
inode | 732 | drivers/scsi/st.c | retval = flush_buffer(inode, filp, 0); |
inode | 939 | drivers/scsi/st.c | st_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 948 | drivers/scsi/st.c | dev = MINOR(inode->i_rdev) & 127; |
inode | 967 | drivers/scsi/st.c | transfer = flush_buffer(inode, filp, 0); |
inode | 1179 | drivers/scsi/st.c | st_set_options(struct inode * inode, long options) |
inode | 1184 | drivers/scsi/st.c | dev = MINOR(inode->i_rdev) & 127; |
inode | 1224 | drivers/scsi/st.c | st_int_ioctl(struct inode * inode,struct file * file, |
inode | 1227 | drivers/scsi/st.c | int dev = MINOR(inode->i_rdev); |
inode | 1428 | drivers/scsi/st.c | ioctl_result = st_int_ioctl(inode, file, MTFSF, 0x3fff); |
inode | 1575 | drivers/scsi/st.c | ioctl_result = st_int_ioctl(inode, file, MTFSF, 1); |
inode | 1577 | drivers/scsi/st.c | ioctl_result = st_int_ioctl(inode, file, MTBSF, 1); |
inode | 1669 | drivers/scsi/st.c | st_ioctl(struct inode * inode,struct file * file, |
inode | 1672 | drivers/scsi/st.c | int dev = MINOR(inode->i_rdev); |
inode | 1701 | drivers/scsi/st.c | i = flush_buffer(inode, file, mtc.mt_op == MTSEEK || |
inode | 1713 | drivers/scsi/st.c | return st_set_options(inode, mtc.mt_count); |
inode | 1715 | drivers/scsi/st.c | return st_int_ioctl(inode, file, mtc.mt_op, mtc.mt_count); |
inode | 1780 | drivers/scsi/st.c | i = flush_buffer(inode, file, 0); |
inode | 61 | drivers/sound/soundcard.c | sound_read (struct inode *inode, struct file *file, char *buf, int count) |
inode | 65 | drivers/sound/soundcard.c | dev = inode->i_rdev; |
inode | 72 | drivers/sound/soundcard.c | sound_write (struct inode *inode, struct file *file, char *buf, int count) |
inode | 76 | drivers/sound/soundcard.c | dev = inode->i_rdev; |
inode | 83 | drivers/sound/soundcard.c | sound_lseek (struct inode *inode, struct file *file, off_t offset, int orig) |
inode | 89 | drivers/sound/soundcard.c | sound_open (struct inode *inode, struct file *file) |
inode | 93 | drivers/sound/soundcard.c | dev = inode->i_rdev; |
inode | 115 | drivers/sound/soundcard.c | sound_release (struct inode *inode, struct file *file) |
inode | 119 | drivers/sound/soundcard.c | dev = inode->i_rdev; |
inode | 126 | drivers/sound/soundcard.c | sound_ioctl (struct inode *inode, struct file *file, |
inode | 131 | drivers/sound/soundcard.c | dev = inode->i_rdev; |
inode | 138 | drivers/sound/soundcard.c | sound_select (struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 142 | drivers/sound/soundcard.c | dev = inode->i_rdev; |
inode | 162 | fs/binfmt_elf.c | struct inode * interpreter_inode) |
inode | 250 | fs/binfmt_elf.c | struct inode * interpreter_inode) |
inode | 304 | fs/binfmt_elf.c | struct inode *interpreter_inode; |
inode | 339 | fs/binfmt_elf.c | (!bprm->inode->i_op || !bprm->inode->i_op->default_file_ops || |
inode | 340 | fs/binfmt_elf.c | !bprm->inode->i_op->default_file_ops->mmap)){ |
inode | 352 | fs/binfmt_elf.c | retval = read_exec(bprm->inode, elf_ex.e_phoff, (char *) elf_phdata, |
inode | 366 | fs/binfmt_elf.c | elf_exec_fileno = open_inode(bprm->inode, O_RDONLY); |
inode | 393 | fs/binfmt_elf.c | retval = read_exec(bprm->inode,elf_ppnt->p_offset,elf_interpreter, |
inode | 578 | fs/binfmt_elf.c | current->executable = bprm->inode; |
inode | 579 | fs/binfmt_elf.c | bprm->inode->i_count++; |
inode | 640 | fs/binfmt_elf.c | struct inode * inode; |
inode | 651 | fs/binfmt_elf.c | inode = file->f_inode; |
inode | 655 | fs/binfmt_elf.c | if (file->f_op->read(inode, file, (char *) &elf_ex, sizeof(elf_ex)) != sizeof(elf_ex)) { |
inode | 671 | fs/binfmt_elf.c | (!inode->i_op || !inode->i_op->default_file_ops->mmap)){ |
inode | 688 | fs/binfmt_elf.c | retval = read_exec(inode, elf_ex.e_phoff, (char *) elf_phdata, |
inode | 23 | fs/block_dev.c | int block_write(struct inode * inode, struct file * filp, 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 | 313 | fs/block_dev.c | int block_fsync(struct inode *inode, struct file *filp) |
inode | 315 | fs/block_dev.c | return fsync_dev (inode->i_rdev); |
inode | 235 | fs/buffer.c | int file_fsync (struct inode *inode, struct file *filp) |
inode | 237 | fs/buffer.c | return fsync_dev(inode->i_dev); |
inode | 243 | fs/buffer.c | struct inode * inode; |
inode | 245 | fs/buffer.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 249 | fs/buffer.c | if (file->f_op->fsync(inode,file)) |
inode | 133 | fs/dcache.c | static struct dir_cache_entry * find_entry(struct inode * dir, const char * name, int len, struct hash_list * hash) |
inode | 172 | fs/dcache.c | int dcache_lookup(struct inode * dir, const char * name, int len, unsigned long * ino) |
inode | 188 | fs/dcache.c | void dcache_add(struct inode * dir, const char * name, int len, unsigned long ino) |
inode | 171 | fs/devices.c | int blkdev_open(struct inode * inode, struct file * filp) |
inode | 175 | fs/devices.c | i = MAJOR(inode->i_rdev); |
inode | 180 | fs/devices.c | return filp->f_op->open(inode,filp); |
inode | 222 | fs/devices.c | int chrdev_open(struct inode * inode, struct file * filp) |
inode | 226 | fs/devices.c | i = MAJOR(inode->i_rdev); |
inode | 231 | fs/devices.c | return filp->f_op->open(inode,filp); |
inode | 105 | fs/exec.c | int open_inode(struct inode * inode, int mode) |
inode | 110 | fs/exec.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 129 | fs/exec.c | f->f_inode = inode; |
inode | 132 | fs/exec.c | f->f_op = inode->i_op->default_file_ops; |
inode | 134 | fs/exec.c | error = f->f_op->open(inode,f); |
inode | 141 | fs/exec.c | inode->i_count++; |
inode | 150 | fs/exec.c | while (file.f_op->write(inode,&file,(char *)(addr),(nr)) != (nr)) goto close_coredump |
inode | 154 | fs/exec.c | if (file.f_op->lseek(inode,&file,(offset),0) != (offset)) \ |
inode | 169 | fs/exec.c | struct inode * inode = NULL; |
inode | 192 | fs/exec.c | if (open_namei(corefile,O_CREAT | 2 | O_TRUNC,0600,&inode,NULL)) { |
inode | 193 | fs/exec.c | inode = NULL; |
inode | 196 | fs/exec.c | if (!S_ISREG(inode->i_mode)) |
inode | 198 | fs/exec.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 200 | fs/exec.c | if (get_write_access(inode)) |
inode | 205 | fs/exec.c | file.f_inode = inode; |
inode | 208 | fs/exec.c | file.f_op = inode->i_op->default_file_ops; |
inode | 210 | fs/exec.c | if (file.f_op->open(inode,&file)) |
inode | 255 | fs/exec.c | file.f_op->release(inode,&file); |
inode | 257 | fs/exec.c | put_write_access(inode); |
inode | 260 | fs/exec.c | iput(inode); |
inode | 462 | fs/exec.c | int read_exec(struct inode *inode, unsigned long offset, |
inode | 468 | fs/exec.c | if (!inode->i_op || !inode->i_op->default_file_ops) |
inode | 473 | fs/exec.c | file.f_inode = inode; |
inode | 476 | fs/exec.c | file.f_op = inode->i_op->default_file_ops; |
inode | 478 | fs/exec.c | if (file.f_op->open(inode,&file)) |
inode | 483 | fs/exec.c | if (file.f_op->lseek(inode,&file,offset,0) != offset) |
inode | 492 | fs/exec.c | result = file.f_op->read(inode, &file, addr, count); |
inode | 495 | fs/exec.c | file.f_op->release(inode,&file); |
inode | 529 | fs/exec.c | permission(bprm->inode,MAY_READ)) |
inode | 563 | fs/exec.c | retval = open_namei(filename, 0, 0, &bprm.inode, NULL); |
inode | 573 | fs/exec.c | if (!S_ISREG(bprm.inode->i_mode)) { /* must be regular file */ |
inode | 577 | fs/exec.c | if (IS_NOEXEC(bprm.inode)) { /* FS mustn't be mounted noexec */ |
inode | 581 | fs/exec.c | if (!bprm.inode->i_sb) { |
inode | 585 | fs/exec.c | i = bprm.inode->i_mode; |
inode | 586 | fs/exec.c | if (IS_NOSUID(bprm.inode) && (((i & S_ISUID) && bprm.inode->i_uid != current-> |
inode | 587 | fs/exec.c | euid) || ((i & S_ISGID) && !in_group_p(bprm.inode->i_gid))) && !suser()) { |
inode | 596 | fs/exec.c | bprm.e_uid = (i & S_ISUID) ? bprm.inode->i_uid : current->euid; |
inode | 597 | fs/exec.c | bprm.e_gid = (i & S_ISGID) ? bprm.inode->i_gid : current->egid; |
inode | 599 | fs/exec.c | if ((retval = permission(bprm.inode, MAY_EXEC)) != 0) |
inode | 601 | fs/exec.c | if (!(bprm.inode->i_mode & 0111) && fsuser()) { |
inode | 606 | fs/exec.c | if (bprm.inode->i_wcount > 0) { |
inode | 613 | fs/exec.c | retval = read_exec(bprm.inode,0,bprm.buf,128); |
inode | 625 | fs/exec.c | iput(bprm.inode); |
inode | 685 | fs/exec.c | retval = open_namei(interp, 0, 0, &bprm.inode, NULL); |
inode | 706 | fs/exec.c | iput(bprm.inode); |
inode | 714 | fs/exec.c | iput(bprm.inode); |
inode | 749 | fs/exec.c | bprm->inode->i_size < ex.a_text+ex.a_data+ex.a_syms+N_TXTOFF(ex)) { |
inode | 761 | fs/exec.c | (fd_offset < bprm->inode->i_sb->s_blocksize)) { |
inode | 782 | fs/exec.c | read_exec(bprm->inode, 32, (char *) 0, ex.a_text+ex.a_data); |
inode | 787 | fs/exec.c | fd = open_inode(bprm->inode, O_RDONLY); |
inode | 797 | fs/exec.c | read_exec(bprm->inode, fd_offset, |
inode | 854 | fs/exec.c | struct inode * inode; |
inode | 861 | fs/exec.c | inode = file->f_inode; |
inode | 864 | fs/exec.c | if (file->f_op->read(inode, file, (char *) &ex, sizeof(ex)) != sizeof(ex)) { |
inode | 872 | fs/exec.c | inode->i_size < ex.a_text+ex.a_data+ex.a_syms+N_TXTOFF(ex)) { |
inode | 876 | fs/exec.c | (N_TXTOFF(ex) < inode->i_sb->s_blocksize)) { |
inode | 26 | fs/ext/dir.c | static int ext_dir_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 31 | fs/ext/dir.c | static int ext_readdir(struct inode *, struct file *, struct dirent *, int); |
inode | 67 | fs/ext/dir.c | static int ext_readdir(struct inode * inode, struct file * filp, |
inode | 77 | fs/ext/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 82 | fs/ext/dir.c | while (!ret && filp->f_pos < inode->i_size) { |
inode | 84 | fs/ext/dir.c | bh = ext_bread(inode,(filp->f_pos)>>BLOCK_SIZE_BITS,0); |
inode | 97 | fs/ext/dir.c | while (!ret && offset < 1024 && filp->f_pos < inode->i_size) { |
inode | 103 | fs/ext/dir.c | inode->i_dev, inode->i_ino, offset, de->rec_len, de->name_len); |
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 | 111 | fs/ext/dir.c | if (de->inode) { |
inode | 118 | fs/ext/dir.c | put_fs_long(de->inode,&dirent->d_ino); |
inode | 34 | fs/ext/file.c | static int ext_file_read(struct inode *, struct file *, char *, int); |
inode | 35 | fs/ext/file.c | static int ext_file_write(struct inode *, struct file *, char *, int); |
inode | 72 | fs/ext/file.c | static int ext_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 82 | fs/ext/file.c | if (!inode) { |
inode | 86 | fs/ext/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 87 | fs/ext/file.c | printk("ext_file_read: mode = %07o\n",inode->i_mode); |
inode | 91 | fs/ext/file.c | size = inode->i_size; |
inode | 107 | fs/ext/file.c | if(blocks < read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9)) |
inode | 108 | fs/ext/file.c | blocks = read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9); |
inode | 128 | fs/ext/file.c | *bhb = ext_getblk(inode, block++, 0); |
inode | 190 | fs/ext/file.c | if (!IS_RDONLY(inode)) { |
inode | 191 | fs/ext/file.c | inode->i_atime = CURRENT_TIME; |
inode | 192 | fs/ext/file.c | inode->i_dirt = 1; |
inode | 197 | fs/ext/file.c | static int ext_file_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 204 | fs/ext/file.c | if (!inode) { |
inode | 208 | fs/ext/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 209 | fs/ext/file.c | printk("ext_file_write: mode = %07o\n",inode->i_mode); |
inode | 217 | fs/ext/file.c | pos = inode->i_size; |
inode | 222 | fs/ext/file.c | bh = ext_getblk(inode,pos/BLOCK_SIZE,1); |
inode | 243 | fs/ext/file.c | if (pos > inode->i_size) { |
inode | 244 | fs/ext/file.c | inode->i_size = pos; |
inode | 245 | fs/ext/file.c | inode->i_dirt = 1; |
inode | 254 | fs/ext/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 256 | 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 | 24 | fs/ext/inode.c | void ext_put_inode(struct inode *inode) |
inode | 26 | fs/ext/inode.c | if (inode->i_nlink) |
inode | 28 | fs/ext/inode.c | inode->i_size = 0; |
inode | 29 | fs/ext/inode.c | ext_truncate(inode); |
inode | 30 | fs/ext/inode.c | ext_free_inode(inode); |
inode | 164 | fs/ext/inode.c | #define inode_bmap(inode,nr) ((inode)->u.ext_i.i_data[(nr)]) |
inode | 177 | fs/ext/inode.c | int ext_bmap(struct inode * inode,int block) |
inode | 190 | fs/ext/inode.c | return inode_bmap(inode,block); |
inode | 193 | fs/ext/inode.c | i = inode_bmap(inode,9); |
inode | 196 | fs/ext/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block); |
inode | 200 | fs/ext/inode.c | i = inode_bmap(inode,10); |
inode | 203 | fs/ext/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block>>8); |
inode | 206 | fs/ext/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 255); |
inode | 209 | fs/ext/inode.c | i = inode_bmap(inode,11); |
inode | 212 | fs/ext/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block>>16); |
inode | 215 | fs/ext/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),(block>>8) & 255); |
inode | 218 | fs/ext/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 255); |
inode | 221 | fs/ext/inode.c | static struct buffer_head * inode_getblk(struct inode * inode, int nr, int create) |
inode | 227 | fs/ext/inode.c | p = inode->u.ext_i.i_data + nr; |
inode | 231 | fs/ext/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 239 | fs/ext/inode.c | tmp = ext_new_block(inode->i_sb); |
inode | 242 | fs/ext/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 244 | fs/ext/inode.c | ext_free_block(inode->i_sb,tmp); |
inode | 249 | fs/ext/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 250 | fs/ext/inode.c | inode->i_dirt = 1; |
inode | 254 | fs/ext/inode.c | static struct buffer_head * block_getblk(struct inode * inode, |
inode | 287 | fs/ext/inode.c | tmp = ext_new_block(inode->i_sb); |
inode | 294 | fs/ext/inode.c | ext_free_block(inode->i_sb,tmp); |
inode | 304 | fs/ext/inode.c | struct buffer_head * ext_getblk(struct inode * inode, int block, int create) |
inode | 317 | fs/ext/inode.c | return inode_getblk(inode,block,create); |
inode | 320 | fs/ext/inode.c | bh = inode_getblk(inode,9,create); |
inode | 321 | fs/ext/inode.c | return block_getblk(inode,bh,block,create); |
inode | 325 | fs/ext/inode.c | bh = inode_getblk(inode,10,create); |
inode | 326 | fs/ext/inode.c | bh = block_getblk(inode,bh,block>>8,create); |
inode | 327 | fs/ext/inode.c | return block_getblk(inode,bh,block & 255,create); |
inode | 330 | fs/ext/inode.c | bh = inode_getblk(inode,11,create); |
inode | 331 | fs/ext/inode.c | bh = block_getblk(inode,bh,block>>16,create); |
inode | 332 | fs/ext/inode.c | bh = block_getblk(inode,bh,(block>>8) & 255,create); |
inode | 333 | fs/ext/inode.c | return block_getblk(inode,bh,block & 255,create); |
inode | 336 | fs/ext/inode.c | struct buffer_head * ext_bread(struct inode * inode, int block, int create) |
inode | 340 | fs/ext/inode.c | bh = ext_getblk(inode,block,create); |
inode | 351 | fs/ext/inode.c | void ext_read_inode(struct inode * inode) |
inode | 357 | fs/ext/inode.c | block = 2 + (inode->i_ino-1)/EXT_INODES_PER_BLOCK; |
inode | 358 | fs/ext/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) |
inode | 361 | fs/ext/inode.c | (inode->i_ino-1)%EXT_INODES_PER_BLOCK; |
inode | 362 | fs/ext/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 363 | fs/ext/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 364 | fs/ext/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 365 | fs/ext/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 366 | fs/ext/inode.c | inode->i_size = raw_inode->i_size; |
inode | 367 | fs/ext/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = raw_inode->i_time; |
inode | 368 | fs/ext/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 369 | fs/ext/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 370 | fs/ext/inode.c | inode->i_rdev = raw_inode->i_zone[0]; |
inode | 372 | fs/ext/inode.c | inode->u.ext_i.i_data[block] = raw_inode->i_zone[block]; |
inode | 374 | fs/ext/inode.c | inode->i_op = NULL; |
inode | 375 | fs/ext/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 376 | fs/ext/inode.c | inode->i_op = &ext_file_inode_operations; |
inode | 377 | fs/ext/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 378 | fs/ext/inode.c | inode->i_op = &ext_dir_inode_operations; |
inode | 379 | fs/ext/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 380 | fs/ext/inode.c | inode->i_op = &ext_symlink_inode_operations; |
inode | 381 | fs/ext/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 382 | fs/ext/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 383 | fs/ext/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 384 | fs/ext/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 385 | fs/ext/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 386 | fs/ext/inode.c | init_fifo(inode); |
inode | 389 | fs/ext/inode.c | static struct buffer_head * ext_update_inode(struct inode * inode) |
inode | 395 | fs/ext/inode.c | block = 2 + (inode->i_ino-1)/EXT_INODES_PER_BLOCK; |
inode | 396 | fs/ext/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) |
inode | 399 | fs/ext/inode.c | (inode->i_ino-1)%EXT_INODES_PER_BLOCK; |
inode | 400 | fs/ext/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 401 | fs/ext/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 402 | fs/ext/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 403 | fs/ext/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 404 | fs/ext/inode.c | raw_inode->i_size = inode->i_size; |
inode | 405 | fs/ext/inode.c | raw_inode->i_time = inode->i_mtime; |
inode | 406 | fs/ext/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 407 | fs/ext/inode.c | raw_inode->i_zone[0] = inode->i_rdev; |
inode | 409 | fs/ext/inode.c | raw_inode->i_zone[block] = inode->u.ext_i.i_data[block]; |
inode | 411 | fs/ext/inode.c | inode->i_dirt=0; |
inode | 415 | fs/ext/inode.c | void ext_write_inode(struct inode * inode) |
inode | 418 | fs/ext/inode.c | bh = ext_update_inode (inode); |
inode | 422 | fs/ext/inode.c | int ext_sync_inode (struct inode *inode) |
inode | 427 | fs/ext/inode.c | bh = ext_update_inode(inode); |
inode | 435 | fs/ext/inode.c | 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 | 149 | fs/ext/namei.c | int ext_lookup(struct inode * dir,const char * name, int len, |
inode | 150 | fs/ext/namei.c | struct inode ** result) |
inode | 167 | fs/ext/namei.c | ino = de->inode; |
inode | 187 | fs/ext/namei.c | static struct buffer_head * ext_add_entry(struct inode * dir, |
inode | 234 | fs/ext/namei.c | de->inode = 0; |
inode | 257 | fs/ext/namei.c | de->inode=0; |
inode | 274 | fs/ext/namei.c | if (!de->inode && de->rec_len >= rec_len) { |
inode | 282 | fs/ext/namei.c | de1->inode = 0; |
inode | 303 | fs/ext/namei.c | int ext_create(struct inode * dir,const char * name, int len, int mode, |
inode | 304 | fs/ext/namei.c | struct inode ** result) |
inode | 306 | fs/ext/namei.c | struct inode * inode; |
inode | 313 | fs/ext/namei.c | inode = ext_new_inode(dir); |
inode | 314 | fs/ext/namei.c | if (!inode) { |
inode | 318 | fs/ext/namei.c | inode->i_op = &ext_file_inode_operations; |
inode | 319 | fs/ext/namei.c | inode->i_mode = mode; |
inode | 320 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 323 | fs/ext/namei.c | inode->i_nlink--; |
inode | 324 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 325 | fs/ext/namei.c | iput(inode); |
inode | 329 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 333 | fs/ext/namei.c | *result = inode; |
inode | 337 | fs/ext/namei.c | int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
inode | 339 | fs/ext/namei.c | struct inode * inode; |
inode | 351 | fs/ext/namei.c | inode = ext_new_inode(dir); |
inode | 352 | fs/ext/namei.c | if (!inode) { |
inode | 356 | fs/ext/namei.c | inode->i_uid = current->fsuid; |
inode | 357 | fs/ext/namei.c | inode->i_mode = mode; |
inode | 358 | fs/ext/namei.c | inode->i_op = NULL; |
inode | 359 | fs/ext/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 360 | fs/ext/namei.c | inode->i_op = &ext_file_inode_operations; |
inode | 361 | fs/ext/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 362 | fs/ext/namei.c | inode->i_op = &ext_dir_inode_operations; |
inode | 364 | fs/ext/namei.c | inode->i_mode |= S_ISGID; |
inode | 366 | fs/ext/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 367 | fs/ext/namei.c | inode->i_op = &ext_symlink_inode_operations; |
inode | 368 | fs/ext/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 369 | fs/ext/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 370 | fs/ext/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 371 | fs/ext/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 372 | fs/ext/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 373 | fs/ext/namei.c | init_fifo(inode); |
inode | 375 | fs/ext/namei.c | inode->i_rdev = rdev; |
inode | 377 | fs/ext/namei.c | inode->i_mtime = inode->i_atime = CURRENT_TIME; |
inode | 379 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 382 | fs/ext/namei.c | inode->i_nlink--; |
inode | 383 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 384 | fs/ext/namei.c | iput(inode); |
inode | 388 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 392 | fs/ext/namei.c | iput(inode); |
inode | 396 | fs/ext/namei.c | int ext_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 398 | fs/ext/namei.c | struct inode * inode; |
inode | 408 | fs/ext/namei.c | inode = ext_new_inode(dir); |
inode | 409 | fs/ext/namei.c | if (!inode) { |
inode | 413 | fs/ext/namei.c | inode->i_op = &ext_dir_inode_operations; |
inode | 414 | fs/ext/namei.c | inode->i_size = 2 * 16; /* Each entry is coded on 16 bytes for "." and ".." |
inode | 420 | fs/ext/namei.c | inode->i_mtime = inode->i_atime = CURRENT_TIME; |
inode | 422 | fs/ext/namei.c | dir_block = ext_bread(inode,0,1); |
inode | 425 | fs/ext/namei.c | inode->i_nlink--; |
inode | 426 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 427 | fs/ext/namei.c | iput(inode); |
inode | 431 | fs/ext/namei.c | de->inode=inode->i_ino; |
inode | 436 | fs/ext/namei.c | de->inode = dir->i_ino; |
inode | 440 | fs/ext/namei.c | inode->i_nlink = 2; |
inode | 443 | fs/ext/namei.c | inode->i_mode = S_IFDIR | (mode & 0777 & ~current->fs->umask); |
inode | 445 | fs/ext/namei.c | inode->i_mode |= S_ISGID; |
inode | 446 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 450 | fs/ext/namei.c | inode->i_nlink=0; |
inode | 451 | fs/ext/namei.c | iput(inode); |
inode | 454 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 459 | fs/ext/namei.c | iput(inode); |
inode | 467 | fs/ext/namei.c | static int empty_dir(struct inode * inode) |
inode | 473 | fs/ext/namei.c | if (inode->i_size < 2 * 12 || !(bh = ext_bread(inode,0,0))) { |
inode | 474 | fs/ext/namei.c | printk("warning - bad directory on dev %04x\n",inode->i_dev); |
inode | 479 | fs/ext/namei.c | if (de->inode != inode->i_ino || !de1->inode || |
inode | 481 | fs/ext/namei.c | printk("warning - bad directory on dev %04x\n",inode->i_dev); |
inode | 486 | fs/ext/namei.c | while (offset < inode->i_size ) { |
inode | 489 | fs/ext/namei.c | bh = ext_bread(inode, offset >> BLOCK_SIZE_BITS,1); |
inode | 500 | fs/ext/namei.c | inode->i_dev, inode->i_ino, offset, de->rec_len, de->name_len); |
inode | 504 | fs/ext/namei.c | if (de->inode) { |
inode | 518 | fs/ext/namei.c | if (nde && !nde->inode) |
inode | 520 | fs/ext/namei.c | if (pde && !pde->inode) |
inode | 524 | fs/ext/namei.c | int ext_rmdir(struct inode * dir, const char * name, int len) |
inode | 527 | fs/ext/namei.c | struct inode * inode; |
inode | 531 | fs/ext/namei.c | inode = NULL; |
inode | 537 | fs/ext/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 540 | fs/ext/namei.c | current->fsuid != inode->i_uid && |
inode | 543 | fs/ext/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 545 | fs/ext/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 547 | fs/ext/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 551 | fs/ext/namei.c | if (!empty_dir(inode)) { |
inode | 555 | fs/ext/namei.c | if (inode->i_count > 1) { |
inode | 559 | fs/ext/namei.c | if (inode->i_nlink != 2) |
inode | 560 | fs/ext/namei.c | printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); |
inode | 561 | fs/ext/namei.c | de->inode = 0; |
inode | 565 | fs/ext/namei.c | inode->i_nlink=0; |
inode | 566 | fs/ext/namei.c | inode->i_dirt=1; |
inode | 568 | fs/ext/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 573 | fs/ext/namei.c | iput(inode); |
inode | 578 | fs/ext/namei.c | int ext_unlink(struct inode * dir, const char * name, int len) |
inode | 581 | fs/ext/namei.c | struct inode * inode; |
inode | 586 | fs/ext/namei.c | inode = NULL; |
inode | 590 | fs/ext/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 594 | fs/ext/namei.c | current->fsuid != inode->i_uid && |
inode | 597 | fs/ext/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 599 | fs/ext/namei.c | if (!inode->i_nlink) { |
inode | 601 | fs/ext/namei.c | inode->i_dev,inode->i_ino,inode->i_nlink); |
inode | 602 | fs/ext/namei.c | inode->i_nlink=1; |
inode | 604 | fs/ext/namei.c | de->inode = 0; |
inode | 608 | fs/ext/namei.c | inode->i_nlink--; |
inode | 609 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 610 | fs/ext/namei.c | inode->i_ctime = CURRENT_TIME; |
inode | 611 | fs/ext/namei.c | dir->i_ctime = dir->i_mtime = inode->i_ctime; |
inode | 616 | fs/ext/namei.c | iput(inode); |
inode | 621 | fs/ext/namei.c | int ext_symlink(struct inode * dir, const char * name, int len, const char * symname) |
inode | 624 | fs/ext/namei.c | struct inode * inode = NULL; |
inode | 629 | fs/ext/namei.c | if (!(inode = ext_new_inode(dir))) { |
inode | 633 | fs/ext/namei.c | inode->i_mode = S_IFLNK | 0777; |
inode | 634 | fs/ext/namei.c | inode->i_op = &ext_symlink_inode_operations; |
inode | 635 | fs/ext/namei.c | name_block = ext_bread(inode,0,1); |
inode | 638 | fs/ext/namei.c | inode->i_nlink--; |
inode | 639 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 640 | fs/ext/namei.c | iput(inode); |
inode | 649 | fs/ext/namei.c | inode->i_size = i; |
inode | 650 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 653 | fs/ext/namei.c | inode->i_nlink--; |
inode | 654 | fs/ext/namei.c | inode->i_dirt = 1; |
inode | 655 | fs/ext/namei.c | iput(inode); |
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 | 668 | fs/ext/namei.c | de->inode = inode->i_ino; |
inode | 672 | fs/ext/namei.c | iput(inode); |
inode | 676 | fs/ext/namei.c | int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
inode | 704 | fs/ext/namei.c | de->inode = oldinode->i_ino; |
inode | 715 | fs/ext/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 741 | fs/ext/namei.c | ((struct ext_dir_entry *) buffer)->rec_len))->inode |
inode | 757 | fs/ext/namei.c | static int do_ext_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 758 | fs/ext/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 760 | fs/ext/namei.c | struct inode * old_inode, * new_inode; |
inode | 781 | fs/ext/namei.c | old_inode = __iget(old_dir->i_sb, old_de->inode,0); /* don't cross mnt-points */ |
inode | 791 | fs/ext/namei.c | new_inode = __iget(new_dir->i_sb, new_de->inode,0); /* don't cross mnt-points */ |
inode | 832 | fs/ext/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 834 | fs/ext/namei.c | if (new_de->inode && !new_inode) |
inode | 836 | fs/ext/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 839 | fs/ext/namei.c | old_de->inode = 0; |
inode | 841 | fs/ext/namei.c | new_de->inode = old_inode->i_ino; |
inode | 878 | fs/ext/namei.c | int ext_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 879 | 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 | 47 | fs/ext/symlink.c | static int ext_follow_link(struct inode * dir, struct inode * inode, |
inode | 48 | fs/ext/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 58 | fs/ext/symlink.c | if (!inode) { |
inode | 62 | fs/ext/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 64 | fs/ext/symlink.c | *res_inode = inode; |
inode | 69 | fs/ext/symlink.c | iput(inode); |
inode | 72 | fs/ext/symlink.c | if (!(bh = ext_bread(inode, 0, 0))) { |
inode | 73 | fs/ext/symlink.c | iput(inode); |
inode | 77 | fs/ext/symlink.c | iput(inode); |
inode | 85 | fs/ext/symlink.c | static int ext_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 91 | fs/ext/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 92 | fs/ext/symlink.c | iput(inode); |
inode | 97 | fs/ext/symlink.c | bh = ext_bread(inode, 0, 0); |
inode | 98 | 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 | 25 | fs/ext2/acl.c | int ext2_permission (struct inode * inode, int mask) |
inode | 27 | fs/ext2/acl.c | unsigned short mode = inode->i_mode; |
inode | 32 | fs/ext2/acl.c | if ((mask & S_IWOTH) && IS_IMMUTABLE(inode)) |
inode | 42 | fs/ext2/acl.c | else if (current->fsuid == inode->i_uid) |
inode | 44 | fs/ext2/acl.c | else if (in_group_p (inode->i_gid)) |
inode | 28 | fs/ext2/dir.c | static int ext2_dir_read (struct inode * inode, struct file * filp, |
inode | 34 | fs/ext2/dir.c | static int ext2_readdir (struct inode *, struct file *, struct dirent *, int); |
inode | 74 | fs/ext2/dir.c | int ext2_check_dir_entry (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 | error_msg, offset, (unsigned long) de->inode, de->rec_len, |
inode | 100 | fs/ext2/dir.c | static int ext2_readdir (struct inode * inode, struct file * filp, |
inode | 110 | fs/ext2/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 112 | fs/ext2/dir.c | sb = inode->i_sb; |
inode | 118 | fs/ext2/dir.c | while (count > 0 && !stored && filp->f_pos < inode->i_size) { |
inode | 120 | fs/ext2/dir.c | bh = ext2_bread (inode, blk, 0, &err); |
inode | 132 | fs/ext2/dir.c | tmp = ext2_getblk (inode, ++blk, 0, &err); |
inode | 150 | fs/ext2/dir.c | if (filp->f_version != inode->i_version) { |
inode | 167 | fs/ext2/dir.c | filp->f_version = inode->i_version; |
inode | 170 | fs/ext2/dir.c | while (count > 0 && filp->f_pos < inode->i_size |
inode | 173 | fs/ext2/dir.c | if (!ext2_check_dir_entry ("ext2_readdir", inode, de, |
inode | 182 | fs/ext2/dir.c | if (de->inode) { |
inode | 200 | fs/ext2/dir.c | version = inode->i_version; |
inode | 203 | fs/ext2/dir.c | put_fs_long (de->inode, &dirent->d_ino); |
inode | 207 | fs/ext2/dir.c | if (version != inode->i_version) |
inode | 209 | fs/ext2/dir.c | dcache_add(inode, de->name, de->name_len, |
inode | 210 | fs/ext2/dir.c | de->inode); |
inode | 222 | fs/ext2/dir.c | if (!IS_RDONLY(inode)) { |
inode | 223 | fs/ext2/dir.c | inode->i_atime = CURRENT_TIME; |
inode | 224 | fs/ext2/dir.c | inode->i_dirt = 1; |
inode | 36 | fs/ext2/file.c | static int ext2_file_read (struct inode *, struct file *, char *, int); |
inode | 37 | fs/ext2/file.c | static int ext2_file_write (struct inode *, struct file *, char *, int); |
inode | 38 | fs/ext2/file.c | static void ext2_release_file (struct inode *, struct file *); |
inode | 79 | fs/ext2/file.c | static int ext2_file_read (struct inode * inode, struct file * filp, |
inode | 93 | fs/ext2/file.c | if (!inode) { |
inode | 97 | fs/ext2/file.c | sb = inode->i_sb; |
inode | 98 | fs/ext2/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 100 | fs/ext2/file.c | inode->i_mode); |
inode | 104 | fs/ext2/file.c | size = inode->i_size; |
inode | 120 | fs/ext2/file.c | if (blocks < read_ahead[MAJOR(inode->i_dev)] >> (EXT2_BLOCK_SIZE_BITS(sb) - 9)) |
inode | 121 | fs/ext2/file.c | blocks = read_ahead[MAJOR(inode->i_dev)] >> (EXT2_BLOCK_SIZE_BITS(sb) - 9); |
inode | 146 | fs/ext2/file.c | if(!clusterblocks) clusterblocks = ext2_getcluster(inode, block); |
inode | 150 | fs/ext2/file.c | *bhb = ext2_getblk (inode, block++, 0, &err); |
inode | 223 | fs/ext2/file.c | if (!IS_RDONLY(inode)) { |
inode | 224 | fs/ext2/file.c | inode->i_atime = CURRENT_TIME; |
inode | 225 | fs/ext2/file.c | inode->i_dirt = 1; |
inode | 230 | fs/ext2/file.c | static int ext2_file_write (struct inode * inode, struct file * filp, |
inode | 244 | fs/ext2/file.c | if (!inode) { |
inode | 248 | fs/ext2/file.c | sb = inode->i_sb; |
inode | 255 | fs/ext2/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 257 | fs/ext2/file.c | inode->i_mode); |
inode | 260 | fs/ext2/file.c | down(&inode->i_sem); |
inode | 262 | fs/ext2/file.c | pos = inode->i_size; |
inode | 273 | fs/ext2/file.c | inode->u.ext2_i.i_osync++; |
inode | 281 | fs/ext2/file.c | bh = ext2_getblk (inode, pos2 / sb->s_blocksize, 1, &err); |
inode | 334 | fs/ext2/file.c | if (pos > inode->i_size) |
inode | 335 | fs/ext2/file.c | inode->i_size = pos; |
inode | 337 | fs/ext2/file.c | inode->u.ext2_i.i_osync--; |
inode | 338 | fs/ext2/file.c | up(&inode->i_sem); |
inode | 339 | fs/ext2/file.c | inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 341 | fs/ext2/file.c | inode->i_dirt = 1; |
inode | 350 | fs/ext2/file.c | static void ext2_release_file (struct inode * inode, struct file * filp) |
inode | 353 | 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 | 158 | fs/ext2/ialloc.c | static void set_inode_dtime (struct inode * inode, |
inode | 165 | fs/ext2/ialloc.c | inode_block = gdp->bg_inode_table + (((inode->i_ino - 1) % |
inode | 166 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) / |
inode | 167 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 168 | fs/ext2/ialloc.c | bh = bread (inode->i_sb->s_dev, inode_block, inode->i_sb->s_blocksize); |
inode | 170 | fs/ext2/ialloc.c | ext2_panic (inode->i_sb, "set_inode_dtime", |
inode | 173 | fs/ext2/ialloc.c | inode->i_ino, inode_block); |
inode | 175 | fs/ext2/ialloc.c | (((inode->i_ino - 1) % |
inode | 176 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) % |
inode | 177 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 181 | fs/ext2/ialloc.c | if (IS_SYNC(inode)) { |
inode | 188 | fs/ext2/ialloc.c | void ext2_free_inode (struct inode * inode) |
inode | 199 | fs/ext2/ialloc.c | if (!inode) |
inode | 201 | fs/ext2/ialloc.c | if (!inode->i_dev) { |
inode | 205 | fs/ext2/ialloc.c | if (inode->i_count > 1) { |
inode | 207 | fs/ext2/ialloc.c | inode->i_count); |
inode | 210 | fs/ext2/ialloc.c | if (inode->i_nlink) { |
inode | 212 | fs/ext2/ialloc.c | inode->i_nlink); |
inode | 215 | fs/ext2/ialloc.c | if (!inode->i_sb) { |
inode | 220 | fs/ext2/ialloc.c | ext2_debug ("freeing inode %lu\n", inode->i_ino); |
inode | 222 | fs/ext2/ialloc.c | sb = inode->i_sb; |
inode | 224 | fs/ext2/ialloc.c | if (inode->i_ino < EXT2_FIRST_INO || |
inode | 225 | fs/ext2/ialloc.c | inode->i_ino > sb->u.ext2_sb.s_es->s_inodes_count) { |
inode | 232 | fs/ext2/ialloc.c | block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(sb); |
inode | 233 | fs/ext2/ialloc.c | bit = (inode->i_ino - 1) % EXT2_INODES_PER_GROUP(sb); |
inode | 238 | fs/ext2/ialloc.c | "bit already cleared for inode %lu", inode->i_ino); |
inode | 242 | fs/ext2/ialloc.c | if (S_ISDIR(inode->i_mode)) |
inode | 247 | fs/ext2/ialloc.c | set_inode_dtime (inode, gdp); |
inode | 256 | fs/ext2/ialloc.c | clear_inode (inode); |
inode | 265 | fs/ext2/ialloc.c | static void inc_inode_version (struct inode * inode, |
inode | 273 | fs/ext2/ialloc.c | inode_block = gdp->bg_inode_table + (((inode->i_ino - 1) % |
inode | 274 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) / |
inode | 275 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 276 | fs/ext2/ialloc.c | bh = bread (inode->i_sb->s_dev, inode_block, inode->i_sb->s_blocksize); |
inode | 278 | fs/ext2/ialloc.c | ext2_error (inode->i_sb, "inc_inode_version", |
inode | 281 | fs/ext2/ialloc.c | inode->i_ino, inode_block); |
inode | 282 | fs/ext2/ialloc.c | inode->u.ext2_i.i_version = 1; |
inode | 286 | fs/ext2/ialloc.c | (((inode->i_ino - 1) % |
inode | 287 | fs/ext2/ialloc.c | EXT2_INODES_PER_GROUP(inode->i_sb)) % |
inode | 288 | fs/ext2/ialloc.c | EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 290 | fs/ext2/ialloc.c | inode->u.ext2_i.i_version = raw_inode->i_version; |
inode | 305 | fs/ext2/ialloc.c | struct inode * ext2_new_inode (const struct inode * dir, int mode) |
inode | 311 | fs/ext2/ialloc.c | struct inode * inode; |
inode | 317 | fs/ext2/ialloc.c | if (!dir || !(inode = get_empty_inode ())) |
inode | 320 | fs/ext2/ialloc.c | inode->i_sb = sb; |
inode | 321 | fs/ext2/ialloc.c | inode->i_flags = sb->s_flags; |
inode | 403 | fs/ext2/ialloc.c | iput(inode); |
inode | 427 | fs/ext2/ialloc.c | iput (inode); |
inode | 438 | fs/ext2/ialloc.c | iput (inode); |
inode | 448 | fs/ext2/ialloc.c | inode->i_mode = mode; |
inode | 449 | fs/ext2/ialloc.c | inode->i_sb = sb; |
inode | 450 | fs/ext2/ialloc.c | inode->i_count = 1; |
inode | 451 | fs/ext2/ialloc.c | inode->i_nlink = 1; |
inode | 452 | fs/ext2/ialloc.c | inode->i_dev = sb->s_dev; |
inode | 453 | fs/ext2/ialloc.c | inode->i_uid = current->fsuid; |
inode | 455 | fs/ext2/ialloc.c | inode->i_gid = dir->i_gid; |
inode | 457 | fs/ext2/ialloc.c | inode->i_gid = dir->i_gid; |
inode | 461 | fs/ext2/ialloc.c | inode->i_gid = current->fsgid; |
inode | 462 | fs/ext2/ialloc.c | inode->i_dirt = 1; |
inode | 463 | fs/ext2/ialloc.c | inode->i_ino = j; |
inode | 464 | fs/ext2/ialloc.c | inode->i_blksize = sb->s_blocksize; |
inode | 465 | fs/ext2/ialloc.c | inode->i_blocks = 0; |
inode | 466 | fs/ext2/ialloc.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 467 | fs/ext2/ialloc.c | inode->u.ext2_i.i_flags = dir->u.ext2_i.i_flags; |
inode | 469 | fs/ext2/ialloc.c | inode->u.ext2_i.i_flags &= ~(EXT2_IMMUTABLE_FL | EXT2_APPEND_FL); |
inode | 470 | fs/ext2/ialloc.c | inode->u.ext2_i.i_faddr = 0; |
inode | 471 | fs/ext2/ialloc.c | inode->u.ext2_i.i_frag_no = 0; |
inode | 472 | fs/ext2/ialloc.c | inode->u.ext2_i.i_frag_size = 0; |
inode | 473 | fs/ext2/ialloc.c | inode->u.ext2_i.i_file_acl = 0; |
inode | 474 | fs/ext2/ialloc.c | inode->u.ext2_i.i_dir_acl = 0; |
inode | 475 | fs/ext2/ialloc.c | inode->u.ext2_i.i_dtime = 0; |
inode | 476 | fs/ext2/ialloc.c | inode->u.ext2_i.i_block_group = i; |
inode | 477 | fs/ext2/ialloc.c | inode->i_op = NULL; |
inode | 478 | fs/ext2/ialloc.c | if (inode->u.ext2_i.i_flags & EXT2_SYNC_FL) |
inode | 479 | fs/ext2/ialloc.c | inode->i_flags |= MS_SYNCHRONOUS; |
inode | 480 | fs/ext2/ialloc.c | insert_inode_hash(inode); |
inode | 481 | fs/ext2/ialloc.c | inc_inode_version (inode, gdp, mode); |
inode | 483 | fs/ext2/ialloc.c | ext2_debug ("allocating inode %lu\n", inode->i_ino); |
inode | 486 | fs/ext2/ialloc.c | return inode; |
inode | 29 | fs/ext2/inode.c | void ext2_put_inode (struct inode * inode) |
inode | 31 | fs/ext2/inode.c | ext2_discard_prealloc (inode); |
inode | 32 | fs/ext2/inode.c | if (inode->i_nlink || inode->i_ino == EXT2_ACL_IDX_INO || |
inode | 33 | fs/ext2/inode.c | inode->i_ino == EXT2_ACL_DATA_INO) |
inode | 35 | fs/ext2/inode.c | inode->i_size = 0; |
inode | 36 | fs/ext2/inode.c | if (inode->i_blocks) |
inode | 37 | fs/ext2/inode.c | ext2_truncate (inode); |
inode | 38 | fs/ext2/inode.c | ext2_free_inode (inode); |
inode | 41 | fs/ext2/inode.c | #define inode_bmap(inode, nr) ((inode)->u.ext2_i.i_data[(nr)]) |
inode | 61 | fs/ext2/inode.c | void ext2_discard_prealloc (struct inode * inode) |
inode | 64 | fs/ext2/inode.c | if (inode->u.ext2_i.i_prealloc_count) { |
inode | 65 | fs/ext2/inode.c | int i = inode->u.ext2_i.i_prealloc_count; |
inode | 66 | fs/ext2/inode.c | inode->u.ext2_i.i_prealloc_count = 0; |
inode | 67 | fs/ext2/inode.c | ext2_free_blocks (inode->i_sb, |
inode | 68 | fs/ext2/inode.c | inode->u.ext2_i.i_prealloc_block, |
inode | 74 | fs/ext2/inode.c | static int ext2_alloc_block (struct inode * inode, unsigned long goal) |
inode | 82 | fs/ext2/inode.c | wait_on_super (inode->i_sb); |
inode | 85 | fs/ext2/inode.c | if (inode->u.ext2_i.i_prealloc_count && |
inode | 86 | fs/ext2/inode.c | (goal == inode->u.ext2_i.i_prealloc_block || |
inode | 87 | fs/ext2/inode.c | goal + 1 == inode->u.ext2_i.i_prealloc_block)) |
inode | 89 | fs/ext2/inode.c | result = inode->u.ext2_i.i_prealloc_block++; |
inode | 90 | fs/ext2/inode.c | inode->u.ext2_i.i_prealloc_count--; |
inode | 97 | fs/ext2/inode.c | if (!(bh = getblk (inode->i_sb->s_dev, result, |
inode | 98 | fs/ext2/inode.c | inode->i_sb->s_blocksize))) { |
inode | 99 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_alloc_block", |
inode | 103 | fs/ext2/inode.c | memset(bh->b_data, 0, inode->i_sb->s_blocksize); |
inode | 108 | fs/ext2/inode.c | ext2_discard_prealloc (inode); |
inode | 111 | fs/ext2/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 113 | fs/ext2/inode.c | (inode->i_sb, 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); |
inode | 117 | fs/ext2/inode.c | result = ext2_new_block (inode->i_sb, goal, 0, 0); |
inode | 120 | fs/ext2/inode.c | result = ext2_new_block (inode->i_sb, goal, 0, 0); |
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 | 133 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_bmap", "block < 0"); |
inode | 139 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_bmap", "block > big"); |
inode | 143 | fs/ext2/inode.c | return inode_bmap (inode, block); |
inode | 146 | fs/ext2/inode.c | i = inode_bmap (inode, EXT2_IND_BLOCK); |
inode | 149 | fs/ext2/inode.c | return block_bmap (bread (inode->i_dev, i, |
inode | 150 | fs/ext2/inode.c | inode->i_sb->s_blocksize), block); |
inode | 154 | fs/ext2/inode.c | i = inode_bmap (inode, EXT2_DIND_BLOCK); |
inode | 157 | fs/ext2/inode.c | i = block_bmap (bread (inode->i_dev, i, |
inode | 158 | fs/ext2/inode.c | inode->i_sb->s_blocksize), |
inode | 162 | fs/ext2/inode.c | return block_bmap (bread (inode->i_dev, i, |
inode | 163 | fs/ext2/inode.c | inode->i_sb->s_blocksize), |
inode | 167 | fs/ext2/inode.c | i = inode_bmap (inode, EXT2_TIND_BLOCK); |
inode | 170 | fs/ext2/inode.c | i = block_bmap (bread (inode->i_dev, i, inode->i_sb->s_blocksize), |
inode | 174 | fs/ext2/inode.c | i = block_bmap (bread (inode->i_dev, i, inode->i_sb->s_blocksize), |
inode | 178 | fs/ext2/inode.c | return block_bmap (bread (inode->i_dev, i, inode->i_sb->s_blocksize), |
inode | 182 | fs/ext2/inode.c | static struct buffer_head * inode_getblk (struct inode * inode, int nr, |
inode | 188 | fs/ext2/inode.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 190 | fs/ext2/inode.c | p = inode->u.ext2_i.i_data + nr; |
inode | 194 | fs/ext2/inode.c | result = getblk (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 202 | fs/ext2/inode.c | EXT2_BLOCK_SIZE_BITS(inode->i_sb))) { |
inode | 206 | fs/ext2/inode.c | if (inode->u.ext2_i.i_next_alloc_block == new_block) |
inode | 207 | fs/ext2/inode.c | goal = inode->u.ext2_i.i_next_alloc_goal; |
inode | 213 | fs/ext2/inode.c | if (inode->u.ext2_i.i_data[tmp]) { |
inode | 214 | fs/ext2/inode.c | goal = inode->u.ext2_i.i_data[tmp]; |
inode | 219 | fs/ext2/inode.c | goal = (inode->u.ext2_i.i_block_group * |
inode | 220 | fs/ext2/inode.c | EXT2_BLOCKS_PER_GROUP(inode->i_sb)) + |
inode | 221 | fs/ext2/inode.c | inode->i_sb->u.ext2_sb.s_es->s_first_data_block; |
inode | 226 | fs/ext2/inode.c | tmp = ext2_alloc_block (inode, goal); |
inode | 229 | fs/ext2/inode.c | result = getblk (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 231 | fs/ext2/inode.c | ext2_free_blocks (inode->i_sb, tmp, 1); |
inode | 236 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block = new_block; |
inode | 237 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal = tmp; |
inode | 238 | fs/ext2/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 239 | fs/ext2/inode.c | inode->i_blocks += blocks; |
inode | 240 | fs/ext2/inode.c | if (IS_SYNC(inode) || inode->u.ext2_i.i_osync) |
inode | 241 | fs/ext2/inode.c | ext2_sync_inode (inode); |
inode | 243 | fs/ext2/inode.c | inode->i_dirt = 1; |
inode | 247 | fs/ext2/inode.c | static struct buffer_head * block_getblk (struct inode * inode, |
inode | 255 | fs/ext2/inode.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 281 | fs/ext2/inode.c | EXT2_BLOCK_SIZE_BITS(inode->i_sb))) { |
inode | 286 | fs/ext2/inode.c | if (inode->u.ext2_i.i_next_alloc_block == new_block) |
inode | 287 | fs/ext2/inode.c | goal = inode->u.ext2_i.i_next_alloc_goal; |
inode | 298 | fs/ext2/inode.c | tmp = ext2_alloc_block (inode, goal); |
inode | 305 | fs/ext2/inode.c | ext2_free_blocks (inode->i_sb, tmp, 1); |
inode | 311 | fs/ext2/inode.c | if (IS_SYNC(inode) || inode->u.ext2_i.i_osync) { |
inode | 315 | fs/ext2/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 316 | fs/ext2/inode.c | inode->i_blocks += blocks; |
inode | 317 | fs/ext2/inode.c | inode->i_dirt = 1; |
inode | 318 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block = new_block; |
inode | 319 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal = tmp; |
inode | 324 | fs/ext2/inode.c | static int block_getcluster (struct inode * inode, struct buffer_head * bh, |
inode | 337 | fs/ext2/inode.c | if(nr % (PAGE_SIZE / inode->i_sb->s_blocksize) != 0) goto out; |
inode | 338 | fs/ext2/inode.c | if(nr + 3 > EXT2_ADDR_PER_BLOCK(inode->i_sb)) goto out; |
inode | 340 | fs/ext2/inode.c | for(i=0; i< (PAGE_SIZE / inode->i_sb->s_blocksize); i++) { |
inode | 359 | fs/ext2/inode.c | struct buffer_head * ext2_getblk (struct inode * inode, long block, |
inode | 364 | fs/ext2/inode.c | unsigned long addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 368 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block < 0"); |
inode | 374 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block > big"); |
inode | 384 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block, |
inode | 385 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal); |
inode | 387 | fs/ext2/inode.c | if (block == inode->u.ext2_i.i_next_alloc_block + 1) { |
inode | 388 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block++; |
inode | 389 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal++; |
inode | 395 | fs/ext2/inode.c | return inode_getblk (inode, block, create, b, err); |
inode | 398 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_IND_BLOCK, create, b, err); |
inode | 399 | fs/ext2/inode.c | return block_getblk (inode, bh, block, create, |
inode | 400 | fs/ext2/inode.c | inode->i_sb->s_blocksize, b, err); |
inode | 404 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_DIND_BLOCK, create, b, err); |
inode | 405 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block / addr_per_block, create, |
inode | 406 | fs/ext2/inode.c | inode->i_sb->s_blocksize, b, err); |
inode | 407 | fs/ext2/inode.c | return block_getblk (inode, bh, block & (addr_per_block - 1), |
inode | 408 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 411 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_TIND_BLOCK, create, b, err); |
inode | 412 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block/(addr_per_block * addr_per_block), |
inode | 413 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 414 | fs/ext2/inode.c | bh = block_getblk (inode, bh, (block/addr_per_block) & (addr_per_block - 1), |
inode | 415 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, err); |
inode | 416 | fs/ext2/inode.c | return block_getblk (inode, bh, block & (addr_per_block - 1), create, |
inode | 417 | fs/ext2/inode.c | inode->i_sb->s_blocksize, b, err); |
inode | 420 | fs/ext2/inode.c | int ext2_getcluster (struct inode * inode, long block) |
inode | 425 | fs/ext2/inode.c | unsigned long addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 430 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block < 0"); |
inode | 436 | fs/ext2/inode.c | ext2_warning (inode->i_sb, "ext2_getblk", "block > big"); |
inode | 447 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_IND_BLOCK, create, b, &err); |
inode | 448 | fs/ext2/inode.c | return block_getcluster (inode, bh, block, |
inode | 449 | fs/ext2/inode.c | inode->i_sb->s_blocksize); |
inode | 453 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_DIND_BLOCK, create, b, &err); |
inode | 454 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block / addr_per_block, create, |
inode | 455 | fs/ext2/inode.c | inode->i_sb->s_blocksize, b, &err); |
inode | 456 | fs/ext2/inode.c | return block_getcluster (inode, bh, block & (addr_per_block - 1), |
inode | 457 | fs/ext2/inode.c | inode->i_sb->s_blocksize); |
inode | 460 | fs/ext2/inode.c | bh = inode_getblk (inode, EXT2_TIND_BLOCK, create, b, &err); |
inode | 461 | fs/ext2/inode.c | bh = block_getblk (inode, bh, block/(addr_per_block * addr_per_block), |
inode | 462 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, &err); |
inode | 463 | fs/ext2/inode.c | bh = block_getblk (inode, bh, (block/addr_per_block) & (addr_per_block - 1), |
inode | 464 | fs/ext2/inode.c | create, inode->i_sb->s_blocksize, b, &err); |
inode | 465 | fs/ext2/inode.c | return block_getcluster (inode, bh, block & (addr_per_block - 1), |
inode | 466 | fs/ext2/inode.c | inode->i_sb->s_blocksize); |
inode | 469 | fs/ext2/inode.c | struct buffer_head * ext2_bread (struct inode * inode, int block, |
inode | 474 | fs/ext2/inode.c | bh = ext2_getblk (inode, block, create, err); |
inode | 486 | fs/ext2/inode.c | void ext2_read_inode (struct inode * inode) |
inode | 496 | fs/ext2/inode.c | if ((inode->i_ino != EXT2_ROOT_INO && inode->i_ino != EXT2_ACL_IDX_INO && |
inode | 497 | fs/ext2/inode.c | inode->i_ino != EXT2_ACL_DATA_INO && inode->i_ino < EXT2_FIRST_INO) || |
inode | 498 | fs/ext2/inode.c | inode->i_ino > inode->i_sb->u.ext2_sb.s_es->s_inodes_count) { |
inode | 499 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_read_inode", |
inode | 500 | fs/ext2/inode.c | "bad inode number: %lu", inode->i_ino); |
inode | 503 | fs/ext2/inode.c | block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(inode->i_sb); |
inode | 504 | fs/ext2/inode.c | if (block_group >= inode->i_sb->u.ext2_sb.s_groups_count) |
inode | 505 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_read_inode", |
inode | 507 | fs/ext2/inode.c | group_desc = block_group / EXT2_DESC_PER_BLOCK(inode->i_sb); |
inode | 508 | fs/ext2/inode.c | desc = block_group % EXT2_DESC_PER_BLOCK(inode->i_sb); |
inode | 509 | fs/ext2/inode.c | bh = inode->i_sb->u.ext2_sb.s_group_desc[group_desc]; |
inode | 511 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_read_inode", |
inode | 515 | fs/ext2/inode.c | (((inode->i_ino - 1) % EXT2_INODES_PER_GROUP(inode->i_sb)) |
inode | 516 | fs/ext2/inode.c | / EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 517 | fs/ext2/inode.c | if (!(bh = bread (inode->i_dev, block, inode->i_sb->s_blocksize))) |
inode | 518 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_read_inode", |
inode | 520 | fs/ext2/inode.c | "inode=%lu, block=%lu", inode->i_ino, block); |
inode | 522 | fs/ext2/inode.c | (inode->i_ino - 1) % EXT2_INODES_PER_BLOCK(inode->i_sb); |
inode | 523 | fs/ext2/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 524 | fs/ext2/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 525 | fs/ext2/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 526 | fs/ext2/inode.c | inode->i_nlink = raw_inode->i_links_count; |
inode | 527 | fs/ext2/inode.c | inode->i_size = raw_inode->i_size; |
inode | 528 | fs/ext2/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 529 | fs/ext2/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 530 | fs/ext2/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 531 | fs/ext2/inode.c | inode->u.ext2_i.i_dtime = raw_inode->i_dtime; |
inode | 532 | fs/ext2/inode.c | inode->i_blksize = inode->i_sb->s_blocksize; |
inode | 533 | fs/ext2/inode.c | inode->i_blocks = raw_inode->i_blocks; |
inode | 534 | fs/ext2/inode.c | inode->i_version = ++event; |
inode | 535 | fs/ext2/inode.c | inode->u.ext2_i.i_flags = raw_inode->i_flags; |
inode | 536 | fs/ext2/inode.c | inode->u.ext2_i.i_faddr = raw_inode->i_faddr; |
inode | 537 | fs/ext2/inode.c | inode->u.ext2_i.i_frag_no = raw_inode->i_frag; |
inode | 538 | fs/ext2/inode.c | inode->u.ext2_i.i_frag_size = raw_inode->i_fsize; |
inode | 539 | fs/ext2/inode.c | inode->u.ext2_i.i_osync = 0; |
inode | 540 | fs/ext2/inode.c | inode->u.ext2_i.i_file_acl = raw_inode->i_file_acl; |
inode | 541 | fs/ext2/inode.c | inode->u.ext2_i.i_dir_acl = raw_inode->i_dir_acl; |
inode | 542 | fs/ext2/inode.c | inode->u.ext2_i.i_version = raw_inode->i_version; |
inode | 543 | fs/ext2/inode.c | inode->u.ext2_i.i_block_group = block_group; |
inode | 544 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_block = 0; |
inode | 545 | fs/ext2/inode.c | inode->u.ext2_i.i_next_alloc_goal = 0; |
inode | 546 | fs/ext2/inode.c | if (inode->u.ext2_i.i_prealloc_count) |
inode | 547 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_read_inode", |
inode | 549 | fs/ext2/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 550 | fs/ext2/inode.c | inode->i_rdev = raw_inode->i_block[0]; |
inode | 552 | fs/ext2/inode.c | inode->u.ext2_i.i_data[block] = raw_inode->i_block[block]; |
inode | 554 | fs/ext2/inode.c | inode->i_op = NULL; |
inode | 555 | fs/ext2/inode.c | if (inode->i_ino == EXT2_ACL_IDX_INO || |
inode | 556 | fs/ext2/inode.c | inode->i_ino == EXT2_ACL_DATA_INO) |
inode | 558 | fs/ext2/inode.c | else if (S_ISREG(inode->i_mode)) |
inode | 559 | fs/ext2/inode.c | inode->i_op = &ext2_file_inode_operations; |
inode | 560 | fs/ext2/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 561 | fs/ext2/inode.c | inode->i_op = &ext2_dir_inode_operations; |
inode | 562 | fs/ext2/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 563 | fs/ext2/inode.c | inode->i_op = &ext2_symlink_inode_operations; |
inode | 564 | fs/ext2/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 565 | fs/ext2/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 566 | fs/ext2/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 567 | fs/ext2/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 568 | fs/ext2/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 569 | fs/ext2/inode.c | init_fifo(inode); |
inode | 570 | fs/ext2/inode.c | if (inode->u.ext2_i.i_flags & EXT2_SYNC_FL) |
inode | 571 | fs/ext2/inode.c | inode->i_flags |= MS_SYNCHRONOUS; |
inode | 572 | fs/ext2/inode.c | if (inode->u.ext2_i.i_flags & EXT2_APPEND_FL) |
inode | 573 | fs/ext2/inode.c | inode->i_flags |= S_APPEND; |
inode | 574 | fs/ext2/inode.c | if (inode->u.ext2_i.i_flags & EXT2_IMMUTABLE_FL) |
inode | 575 | fs/ext2/inode.c | inode->i_flags |= S_IMMUTABLE; |
inode | 578 | fs/ext2/inode.c | static struct buffer_head * ext2_update_inode (struct inode * inode) |
inode | 588 | fs/ext2/inode.c | if ((inode->i_ino != EXT2_ROOT_INO && inode->i_ino < EXT2_FIRST_INO) || |
inode | 589 | fs/ext2/inode.c | inode->i_ino > inode->i_sb->u.ext2_sb.s_es->s_inodes_count) { |
inode | 590 | fs/ext2/inode.c | ext2_error (inode->i_sb, "ext2_write_inode", |
inode | 591 | fs/ext2/inode.c | "bad inode number: %lu", inode->i_ino); |
inode | 594 | fs/ext2/inode.c | block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(inode->i_sb); |
inode | 595 | fs/ext2/inode.c | if (block_group >= inode->i_sb->u.ext2_sb.s_groups_count) |
inode | 596 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_write_inode", |
inode | 598 | fs/ext2/inode.c | group_desc = block_group / EXT2_DESC_PER_BLOCK(inode->i_sb); |
inode | 599 | fs/ext2/inode.c | desc = block_group % EXT2_DESC_PER_BLOCK(inode->i_sb); |
inode | 600 | fs/ext2/inode.c | bh = inode->i_sb->u.ext2_sb.s_group_desc[group_desc]; |
inode | 602 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_write_inode", |
inode | 606 | fs/ext2/inode.c | (((inode->i_ino - 1) % EXT2_INODES_PER_GROUP(inode->i_sb)) |
inode | 607 | fs/ext2/inode.c | / EXT2_INODES_PER_BLOCK(inode->i_sb)); |
inode | 608 | fs/ext2/inode.c | if (!(bh = bread (inode->i_dev, block, inode->i_sb->s_blocksize))) |
inode | 609 | fs/ext2/inode.c | ext2_panic (inode->i_sb, "ext2_write_inode", |
inode | 611 | fs/ext2/inode.c | "inode=%lu, block=%lu", inode->i_ino, block); |
inode | 613 | fs/ext2/inode.c | (inode->i_ino - 1) % EXT2_INODES_PER_BLOCK(inode->i_sb); |
inode | 614 | fs/ext2/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 615 | fs/ext2/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 616 | fs/ext2/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 617 | fs/ext2/inode.c | raw_inode->i_links_count = inode->i_nlink; |
inode | 618 | fs/ext2/inode.c | raw_inode->i_size = inode->i_size; |
inode | 619 | fs/ext2/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 620 | fs/ext2/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 621 | fs/ext2/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 622 | fs/ext2/inode.c | raw_inode->i_blocks = inode->i_blocks; |
inode | 623 | fs/ext2/inode.c | raw_inode->i_dtime = inode->u.ext2_i.i_dtime; |
inode | 624 | fs/ext2/inode.c | raw_inode->i_flags = inode->u.ext2_i.i_flags; |
inode | 625 | fs/ext2/inode.c | raw_inode->i_faddr = inode->u.ext2_i.i_faddr; |
inode | 626 | fs/ext2/inode.c | raw_inode->i_frag = inode->u.ext2_i.i_frag_no; |
inode | 627 | fs/ext2/inode.c | raw_inode->i_fsize = inode->u.ext2_i.i_frag_size; |
inode | 628 | fs/ext2/inode.c | raw_inode->i_file_acl = inode->u.ext2_i.i_file_acl; |
inode | 629 | fs/ext2/inode.c | raw_inode->i_dir_acl = inode->u.ext2_i.i_dir_acl; |
inode | 630 | fs/ext2/inode.c | raw_inode->i_version = inode->u.ext2_i.i_version; |
inode | 631 | fs/ext2/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 632 | fs/ext2/inode.c | raw_inode->i_block[0] = inode->i_rdev; |
inode | 634 | fs/ext2/inode.c | raw_inode->i_block[block] = inode->u.ext2_i.i_data[block]; |
inode | 636 | fs/ext2/inode.c | inode->i_dirt = 0; |
inode | 640 | fs/ext2/inode.c | void ext2_write_inode (struct inode * inode) |
inode | 643 | fs/ext2/inode.c | bh = ext2_update_inode (inode); |
inode | 647 | fs/ext2/inode.c | int ext2_sync_inode (struct inode *inode) |
inode | 652 | fs/ext2/inode.c | bh = ext2_update_inode (inode); |
inode | 660 | fs/ext2/inode.c | inode->i_dev, inode->i_ino); |
inode | 18 | fs/ext2/ioctl.c | int ext2_ioctl (struct inode * inode, struct file * filp, unsigned int cmd, |
inode | 30 | fs/ext2/ioctl.c | put_fs_long (inode->u.ext2_i.i_flags, (long *) arg); |
inode | 38 | fs/ext2/ioctl.c | (inode->u.ext2_i.i_flags & EXT2_IMMUTABLE_FL)) { |
inode | 43 | fs/ext2/ioctl.c | if ((current->fsuid != inode->i_uid) && !fsuser()) |
inode | 45 | fs/ext2/ioctl.c | if (IS_RDONLY(inode)) |
inode | 47 | fs/ext2/ioctl.c | inode->u.ext2_i.i_flags = flags; |
inode | 49 | fs/ext2/ioctl.c | inode->i_flags |= S_APPEND; |
inode | 51 | fs/ext2/ioctl.c | inode->i_flags &= ~S_APPEND; |
inode | 53 | fs/ext2/ioctl.c | inode->i_flags |= S_IMMUTABLE; |
inode | 55 | fs/ext2/ioctl.c | inode->i_flags &= ~S_IMMUTABLE; |
inode | 56 | fs/ext2/ioctl.c | inode->i_ctime = CURRENT_TIME; |
inode | 57 | fs/ext2/ioctl.c | inode->i_dirt = 1; |
inode | 62 | fs/ext2/ioctl.c | put_fs_long (inode->u.ext2_i.i_version, (long *) arg); |
inode | 65 | fs/ext2/ioctl.c | if ((current->fsuid != inode->i_uid) && !fsuser()) |
inode | 67 | fs/ext2/ioctl.c | if (IS_RDONLY(inode)) |
inode | 69 | fs/ext2/ioctl.c | inode->u.ext2_i.i_version = get_fs_long ((long *) arg); |
inode | 70 | fs/ext2/ioctl.c | inode->i_ctime = CURRENT_TIME; |
inode | 71 | fs/ext2/ioctl.c | inode->i_dirt = 1; |
inode | 46 | fs/ext2/namei.c | if (!de || !de->inode || len > EXT2_NAME_LEN) |
inode | 67 | fs/ext2/namei.c | static struct buffer_head * ext2_find_entry (struct inode * dir, |
inode | 132 | fs/ext2/namei.c | if (de->inode != 0 && ext2_match (namelen, name, de)) { |
inode | 162 | fs/ext2/namei.c | int ext2_lookup (struct inode * dir, const char * name, int len, |
inode | 163 | fs/ext2/namei.c | struct inode ** result) |
inode | 195 | fs/ext2/namei.c | ino = de->inode; |
inode | 216 | fs/ext2/namei.c | static struct buffer_head * ext2_add_entry (struct inode * dir, |
inode | 272 | fs/ext2/namei.c | de->inode = 0; |
inode | 289 | fs/ext2/namei.c | if (de->inode != 0 && ext2_match (namelen, name, de)) { |
inode | 294 | fs/ext2/namei.c | if ((de->inode == 0 && de->rec_len >= rec_len) || |
inode | 297 | fs/ext2/namei.c | if (de->inode) { |
inode | 305 | fs/ext2/namei.c | de->inode = 0; |
inode | 354 | fs/ext2/namei.c | dir->inode = 0; |
inode | 364 | fs/ext2/namei.c | int ext2_create (struct inode * dir,const char * name, int len, int mode, |
inode | 365 | fs/ext2/namei.c | struct inode ** result) |
inode | 367 | fs/ext2/namei.c | struct inode * inode; |
inode | 375 | fs/ext2/namei.c | inode = ext2_new_inode (dir, mode); |
inode | 376 | fs/ext2/namei.c | if (!inode) { |
inode | 380 | fs/ext2/namei.c | inode->i_op = &ext2_file_inode_operations; |
inode | 381 | fs/ext2/namei.c | inode->i_mode = mode; |
inode | 382 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 385 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 386 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 387 | fs/ext2/namei.c | iput (inode); |
inode | 391 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 393 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 401 | fs/ext2/namei.c | *result = inode; |
inode | 405 | fs/ext2/namei.c | int ext2_mknod (struct inode * dir, const char * name, int len, int mode, |
inode | 408 | fs/ext2/namei.c | struct inode * inode; |
inode | 421 | fs/ext2/namei.c | inode = ext2_new_inode (dir, mode); |
inode | 422 | fs/ext2/namei.c | if (!inode) { |
inode | 426 | fs/ext2/namei.c | inode->i_uid = current->fsuid; |
inode | 427 | fs/ext2/namei.c | inode->i_mode = mode; |
inode | 428 | fs/ext2/namei.c | inode->i_op = NULL; |
inode | 429 | fs/ext2/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 430 | fs/ext2/namei.c | inode->i_op = &ext2_file_inode_operations; |
inode | 431 | fs/ext2/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 432 | fs/ext2/namei.c | inode->i_op = &ext2_dir_inode_operations; |
inode | 434 | fs/ext2/namei.c | inode->i_mode |= S_ISGID; |
inode | 436 | fs/ext2/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 437 | fs/ext2/namei.c | inode->i_op = &ext2_symlink_inode_operations; |
inode | 438 | fs/ext2/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 439 | fs/ext2/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 440 | fs/ext2/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 441 | fs/ext2/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 442 | fs/ext2/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 443 | fs/ext2/namei.c | init_fifo(inode); |
inode | 445 | fs/ext2/namei.c | inode->i_rdev = rdev; |
inode | 446 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 449 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 450 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 451 | fs/ext2/namei.c | iput (inode); |
inode | 455 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 457 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 465 | fs/ext2/namei.c | iput (inode); |
inode | 469 | fs/ext2/namei.c | int ext2_mkdir (struct inode * dir, const char * name, int len, int mode) |
inode | 471 | fs/ext2/namei.c | struct inode * inode; |
inode | 488 | fs/ext2/namei.c | inode = ext2_new_inode (dir, S_IFDIR); |
inode | 489 | fs/ext2/namei.c | if (!inode) { |
inode | 493 | fs/ext2/namei.c | inode->i_op = &ext2_dir_inode_operations; |
inode | 494 | fs/ext2/namei.c | inode->i_size = inode->i_sb->s_blocksize; |
inode | 495 | fs/ext2/namei.c | dir_block = ext2_bread (inode, 0, 1, &err); |
inode | 498 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 499 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 500 | fs/ext2/namei.c | iput (inode); |
inode | 503 | fs/ext2/namei.c | inode->i_blocks = inode->i_sb->s_blocksize / 512; |
inode | 505 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 510 | fs/ext2/namei.c | de->inode = dir->i_ino; |
inode | 511 | fs/ext2/namei.c | de->rec_len = inode->i_sb->s_blocksize - EXT2_DIR_REC_LEN(1); |
inode | 514 | fs/ext2/namei.c | inode->i_nlink = 2; |
inode | 517 | fs/ext2/namei.c | inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->fs->umask); |
inode | 519 | fs/ext2/namei.c | inode->i_mode |= S_ISGID; |
inode | 520 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 524 | fs/ext2/namei.c | inode->i_nlink = 0; |
inode | 525 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 526 | fs/ext2/namei.c | iput (inode); |
inode | 529 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 531 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 540 | fs/ext2/namei.c | iput (inode); |
inode | 548 | fs/ext2/namei.c | static int empty_dir (struct inode * inode) |
inode | 556 | fs/ext2/namei.c | sb = inode->i_sb; |
inode | 557 | fs/ext2/namei.c | if (inode->i_size < EXT2_DIR_REC_LEN(1) + EXT2_DIR_REC_LEN(2) || |
inode | 558 | fs/ext2/namei.c | !(bh = ext2_bread (inode, 0, 0, &err))) { |
inode | 559 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "empty_dir", |
inode | 560 | fs/ext2/namei.c | "bad directory (dir %lu)", inode->i_ino); |
inode | 565 | fs/ext2/namei.c | if (de->inode != inode->i_ino || !de1->inode || |
inode | 567 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "empty_dir", |
inode | 568 | fs/ext2/namei.c | "bad directory (dir %lu)", inode->i_ino); |
inode | 573 | fs/ext2/namei.c | while (offset < inode->i_size ) { |
inode | 576 | fs/ext2/namei.c | bh = ext2_bread (inode, offset >> EXT2_BLOCK_SIZE_BITS(sb), 1, &err); |
inode | 583 | fs/ext2/namei.c | if (!ext2_check_dir_entry ("empty_dir", inode, de, bh, |
inode | 588 | fs/ext2/namei.c | if (de->inode) { |
inode | 599 | fs/ext2/namei.c | int ext2_rmdir (struct inode * dir, const char * name, int len) |
inode | 602 | fs/ext2/namei.c | struct inode * inode; |
inode | 609 | fs/ext2/namei.c | inode = NULL; |
inode | 615 | fs/ext2/namei.c | if (!(inode = iget (dir->i_sb, de->inode))) |
inode | 617 | fs/ext2/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 619 | fs/ext2/namei.c | if (de->inode != inode->i_ino) { |
inode | 620 | fs/ext2/namei.c | iput(inode); |
inode | 627 | fs/ext2/namei.c | current->fsuid != inode->i_uid && |
inode | 630 | fs/ext2/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 632 | fs/ext2/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 636 | fs/ext2/namei.c | down(&inode->i_sem); |
inode | 637 | fs/ext2/namei.c | if (!empty_dir (inode)) |
inode | 639 | fs/ext2/namei.c | else if (de->inode != inode->i_ino) |
inode | 642 | fs/ext2/namei.c | if (inode->i_count > 1) { |
inode | 650 | fs/ext2/namei.c | inode->i_size = 0; |
inode | 655 | fs/ext2/namei.c | up(&inode->i_sem); |
inode | 663 | fs/ext2/namei.c | if (inode->i_nlink != 2) |
inode | 664 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "ext2_rmdir", |
inode | 666 | fs/ext2/namei.c | inode->i_nlink); |
inode | 667 | fs/ext2/namei.c | inode->i_version = ++event; |
inode | 668 | fs/ext2/namei.c | inode->i_nlink = 0; |
inode | 669 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 671 | fs/ext2/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 675 | fs/ext2/namei.c | iput (inode); |
inode | 680 | fs/ext2/namei.c | int ext2_unlink (struct inode * dir, const char * name, int len) |
inode | 683 | fs/ext2/namei.c | struct inode * inode; |
inode | 691 | fs/ext2/namei.c | inode = NULL; |
inode | 695 | fs/ext2/namei.c | if (!(inode = iget (dir->i_sb, de->inode))) |
inode | 698 | fs/ext2/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 700 | fs/ext2/namei.c | if (IS_APPEND(inode) || IS_IMMUTABLE(inode)) |
inode | 702 | fs/ext2/namei.c | if (de->inode != inode->i_ino) { |
inode | 703 | fs/ext2/namei.c | iput(inode); |
inode | 710 | fs/ext2/namei.c | current->fsuid != inode->i_uid && |
inode | 713 | fs/ext2/namei.c | if (!inode->i_nlink) { |
inode | 714 | fs/ext2/namei.c | ext2_warning (inode->i_sb, "ext2_unlink", |
inode | 716 | fs/ext2/namei.c | inode->i_ino, inode->i_nlink); |
inode | 717 | fs/ext2/namei.c | inode->i_nlink = 1; |
inode | 730 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 731 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 732 | fs/ext2/namei.c | inode->i_ctime = dir->i_ctime; |
inode | 736 | fs/ext2/namei.c | iput (inode); |
inode | 741 | fs/ext2/namei.c | int ext2_symlink (struct inode * dir, const char * name, int len, |
inode | 745 | fs/ext2/namei.c | struct inode * inode = NULL; |
inode | 752 | fs/ext2/namei.c | if (!(inode = ext2_new_inode (dir, S_IFLNK))) { |
inode | 756 | fs/ext2/namei.c | inode->i_mode = S_IFLNK | S_IRWXUGO; |
inode | 757 | fs/ext2/namei.c | inode->i_op = &ext2_symlink_inode_operations; |
inode | 758 | fs/ext2/namei.c | for (l = 0; l < inode->i_sb->s_blocksize - 1 && |
inode | 765 | fs/ext2/namei.c | name_block = ext2_bread (inode, 0, 1, &err); |
inode | 768 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 769 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 770 | fs/ext2/namei.c | iput (inode); |
inode | 775 | fs/ext2/namei.c | link = (char *) inode->u.ext2_i.i_data; |
inode | 781 | fs/ext2/namei.c | while (i < inode->i_sb->s_blocksize - 1 && (c = *(symname++))) |
inode | 788 | fs/ext2/namei.c | inode->i_size = i; |
inode | 789 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 792 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 793 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 794 | fs/ext2/namei.c | iput (inode); |
inode | 801 | fs/ext2/namei.c | inode->i_nlink--; |
inode | 802 | fs/ext2/namei.c | inode->i_dirt = 1; |
inode | 803 | fs/ext2/namei.c | iput (inode); |
inode | 807 | fs/ext2/namei.c | de->inode = inode->i_ino; |
inode | 809 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 817 | fs/ext2/namei.c | iput (inode); |
inode | 821 | fs/ext2/namei.c | int ext2_link (struct inode * oldinode, struct inode * dir, |
inode | 856 | fs/ext2/namei.c | de->inode = oldinode->i_ino; |
inode | 858 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
inode | 873 | fs/ext2/namei.c | static int subdir (struct inode * new_inode, struct inode * old_inode) |
inode | 899 | fs/ext2/namei.c | ((struct ext2_dir_entry *) buffer)->rec_len))->inode |
inode | 916 | fs/ext2/namei.c | static int do_ext2_rename (struct inode * old_dir, const char * old_name, |
inode | 917 | fs/ext2/namei.c | int old_len, struct inode * new_dir, |
inode | 920 | fs/ext2/namei.c | struct inode * old_inode, * new_inode; |
inode | 946 | fs/ext2/namei.c | old_inode = __iget (old_dir->i_sb, old_de->inode, 0); /* don't cross mnt-points */ |
inode | 958 | fs/ext2/namei.c | new_inode = __iget (new_dir->i_sb, new_de->inode, 0); /* no mntp cross */ |
inode | 1012 | fs/ext2/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 1014 | fs/ext2/namei.c | if (new_de->inode && !new_inode) |
inode | 1016 | fs/ext2/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 1021 | fs/ext2/namei.c | new_de->inode = old_inode->i_ino; |
inode | 1022 | fs/ext2/namei.c | dcache_add(new_dir, new_de->name, new_de->name_len, new_de->inode); |
inode | 1085 | fs/ext2/namei.c | int ext2_rename (struct inode * old_dir, const char * old_name, int old_len, |
inode | 1086 | fs/ext2/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 25 | fs/ext2/symlink.c | static int ext2_readlink (struct inode *, char *, int); |
inode | 26 | fs/ext2/symlink.c | static int ext2_follow_link (struct inode *, struct inode *, int, int, |
inode | 27 | fs/ext2/symlink.c | struct inode **); |
inode | 51 | fs/ext2/symlink.c | static int ext2_follow_link(struct inode * dir, struct inode * inode, |
inode | 52 | fs/ext2/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 63 | fs/ext2/symlink.c | if (!inode) { |
inode | 67 | fs/ext2/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 69 | fs/ext2/symlink.c | *res_inode = inode; |
inode | 74 | fs/ext2/symlink.c | iput (inode); |
inode | 77 | fs/ext2/symlink.c | if (inode->i_blocks) { |
inode | 78 | fs/ext2/symlink.c | if (!(bh = ext2_bread (inode, 0, 0, &error))) { |
inode | 80 | fs/ext2/symlink.c | iput (inode); |
inode | 85 | fs/ext2/symlink.c | link = (char *) inode->u.ext2_i.i_data; |
inode | 89 | fs/ext2/symlink.c | iput (inode); |
inode | 95 | fs/ext2/symlink.c | static int ext2_readlink (struct inode * inode, char * buffer, int buflen) |
inode | 102 | fs/ext2/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 103 | fs/ext2/symlink.c | iput (inode); |
inode | 106 | fs/ext2/symlink.c | if (buflen > inode->i_sb->s_blocksize - 1) |
inode | 107 | fs/ext2/symlink.c | buflen = inode->i_sb->s_blocksize - 1; |
inode | 108 | fs/ext2/symlink.c | if (inode->i_blocks) { |
inode | 109 | fs/ext2/symlink.c | bh = ext2_bread (inode, 0, 0, &err); |
inode | 111 | fs/ext2/symlink.c | iput (inode); |
inode | 117 | fs/ext2/symlink.c | link = (char *) inode->u.ext2_i.i_data; |
inode | 123 | fs/ext2/symlink.c | iput (inode); |
inode | 46 | fs/ext2/truncate.c | static int trunc_direct (struct inode * inode) |
inode | 54 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 55 | fs/ext2/truncate.c | #define DIRECT_BLOCK ((inode->i_size + inode->i_sb->s_blocksize - 1) / \ |
inode | 56 | fs/ext2/truncate.c | inode->i_sb->s_blocksize) |
inode | 61 | fs/ext2/truncate.c | p = inode->u.ext2_i.i_data + i; |
inode | 65 | fs/ext2/truncate.c | if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) |
inode | 66 | fs/ext2/truncate.c | bh = getblk (inode->i_dev, tmp, |
inode | 67 | fs/ext2/truncate.c | inode->i_sb->s_blocksize); |
inode | 69 | fs/ext2/truncate.c | bh = get_hash_table (inode->i_dev, tmp, |
inode | 70 | fs/ext2/truncate.c | inode->i_sb->s_blocksize); |
inode | 81 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 82 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 83 | fs/ext2/truncate.c | if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) { |
inode | 84 | fs/ext2/truncate.c | memset(bh->b_data, RANDOM_INT, inode->i_sb->s_blocksize); |
inode | 94 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, block_to_free, free_count); |
inode | 101 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, block_to_free, free_count); |
inode | 105 | fs/ext2/truncate.c | static int trunc_indirect (struct inode * inode, int offset, u32 * p) |
inode | 114 | fs/ext2/truncate.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 115 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 122 | fs/ext2/truncate.c | ind_bh = bread (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 141 | fs/ext2/truncate.c | if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) |
inode | 142 | fs/ext2/truncate.c | bh = getblk (inode->i_dev, tmp, |
inode | 143 | fs/ext2/truncate.c | inode->i_sb->s_blocksize); |
inode | 145 | fs/ext2/truncate.c | bh = get_hash_table (inode->i_dev, tmp, |
inode | 146 | fs/ext2/truncate.c | inode->i_sb->s_blocksize); |
inode | 158 | fs/ext2/truncate.c | if (inode->u.ext2_i.i_flags & EXT2_SECRM_FL) { |
inode | 159 | fs/ext2/truncate.c | memset(bh->b_data, RANDOM_INT, inode->i_sb->s_blocksize); |
inode | 169 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, block_to_free, free_count); |
inode | 174 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 175 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 178 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, block_to_free, free_count); |
inode | 189 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 190 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 191 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, tmp, 1); |
inode | 193 | fs/ext2/truncate.c | if (IS_SYNC(inode) && ind_bh->b_dirt) { |
inode | 201 | fs/ext2/truncate.c | static int trunc_dindirect (struct inode * inode, int offset, |
inode | 208 | fs/ext2/truncate.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 209 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 216 | fs/ext2/truncate.c | dind_bh = bread (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 235 | fs/ext2/truncate.c | retry |= trunc_indirect (inode, offset + (i * addr_per_block), |
inode | 249 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 250 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 251 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, tmp, 1); |
inode | 253 | fs/ext2/truncate.c | if (IS_SYNC(inode) && dind_bh->b_dirt) { |
inode | 261 | fs/ext2/truncate.c | static int trunc_tindirect (struct inode * inode) |
inode | 267 | fs/ext2/truncate.c | int addr_per_block = EXT2_ADDR_PER_BLOCK(inode->i_sb); |
inode | 268 | fs/ext2/truncate.c | int blocks = inode->i_sb->s_blocksize / 512; |
inode | 274 | fs/ext2/truncate.c | p = inode->u.ext2_i.i_data + EXT2_TIND_BLOCK; |
inode | 277 | fs/ext2/truncate.c | tind_bh = bread (inode->i_dev, tmp, inode->i_sb->s_blocksize); |
inode | 293 | fs/ext2/truncate.c | retry |= trunc_dindirect(inode, EXT2_NDIR_BLOCKS + |
inode | 308 | fs/ext2/truncate.c | inode->i_blocks -= blocks; |
inode | 309 | fs/ext2/truncate.c | inode->i_dirt = 1; |
inode | 310 | fs/ext2/truncate.c | ext2_free_blocks (inode->i_sb, tmp, 1); |
inode | 312 | fs/ext2/truncate.c | if (IS_SYNC(inode) && tind_bh->b_dirt) { |
inode | 320 | 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 | down(&inode->i_sem); |
inode | 332 | fs/ext2/truncate.c | retry = trunc_direct(inode); |
inode | 333 | fs/ext2/truncate.c | retry |= trunc_indirect (inode, EXT2_IND_BLOCK, |
inode | 334 | fs/ext2/truncate.c | (u32 *) &inode->u.ext2_i.i_data[EXT2_IND_BLOCK]); |
inode | 335 | fs/ext2/truncate.c | retry |= trunc_dindirect (inode, EXT2_IND_BLOCK + |
inode | 336 | fs/ext2/truncate.c | EXT2_ADDR_PER_BLOCK(inode->i_sb), |
inode | 337 | fs/ext2/truncate.c | (u32 *) &inode->u.ext2_i.i_data[EXT2_DIND_BLOCK]); |
inode | 338 | fs/ext2/truncate.c | retry |= trunc_tindirect (inode); |
inode | 339 | fs/ext2/truncate.c | up(&inode->i_sem); |
inode | 342 | fs/ext2/truncate.c | if (IS_SYNC(inode) && inode->i_dirt) |
inode | 343 | fs/ext2/truncate.c | ext2_sync_inode (inode); |
inode | 347 | fs/ext2/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 348 | fs/ext2/truncate.c | inode->i_dirt = 1; |
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 | 152 | fs/fifo.c | void init_fifo(struct inode * inode) |
inode | 154 | fs/fifo.c | inode->i_op = &fifo_inode_operations; |
inode | 155 | fs/fifo.c | inode->i_pipe = 1; |
inode | 156 | fs/fifo.c | PIPE_LOCK(*inode) = 0; |
inode | 157 | fs/fifo.c | PIPE_BASE(*inode) = NULL; |
inode | 158 | fs/fifo.c | PIPE_START(*inode) = PIPE_LEN(*inode) = 0; |
inode | 159 | fs/fifo.c | PIPE_RD_OPENERS(*inode) = PIPE_WR_OPENERS(*inode) = 0; |
inode | 160 | fs/fifo.c | PIPE_WAIT(*inode) = NULL; |
inode | 161 | fs/fifo.c | PIPE_READERS(*inode) = PIPE_WRITERS(*inode) = 0; |
inode | 129 | fs/hpfs/hpfs_fs.c | static void hpfs_read_inode(struct inode *); |
inode | 148 | fs/hpfs/hpfs_fs.c | static int hpfs_file_read(struct inode *, struct file *, char *, int); |
inode | 149 | fs/hpfs/hpfs_fs.c | static secno hpfs_bmap(struct inode *, unsigned); |
inode | 179 | fs/hpfs/hpfs_fs.c | (int (*)(struct inode *, int)) |
inode | 187 | fs/hpfs/hpfs_fs.c | static int hpfs_dir_read(struct inode *inode, struct file *filp, |
inode | 189 | fs/hpfs/hpfs_fs.c | static int hpfs_readdir(struct inode *inode, struct file *filp, |
inode | 191 | fs/hpfs/hpfs_fs.c | static int hpfs_lookup(struct inode *, const char *, int, struct inode **); |
inode | 240 | fs/hpfs/hpfs_fs.c | static void count_dnodes(struct inode *inode, dnode_secno dno, |
inode | 244 | fs/hpfs/hpfs_fs.c | static secno bplus_lookup(struct inode *inode, struct bplus_header *b, |
inode | 246 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_dirent(struct inode *inode, dnode_secno dno, |
inode | 249 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_pos_dirent(struct inode *inode, loff_t *posp, |
inode | 253 | fs/hpfs/hpfs_fs.c | static dnode_secno dir_subdno(struct inode *inode, unsigned pos); |
inode | 622 | fs/hpfs/hpfs_fs.c | static void hpfs_read_inode(struct inode *inode) |
inode | 624 | fs/hpfs/hpfs_fs.c | struct super_block *s = inode->i_sb; |
inode | 628 | fs/hpfs/hpfs_fs.c | inode->i_op = 0; |
inode | 629 | fs/hpfs/hpfs_fs.c | inode->i_mode = 0; |
inode | 631 | fs/hpfs/hpfs_fs.c | if (inode->i_ino == 0 |
inode | 632 | fs/hpfs/hpfs_fs.c | || ino_secno(inode->i_ino) >= inode->i_sb->s_hpfs_fs_size) { |
inode | 641 | fs/hpfs/hpfs_fs.c | inode->i_uid = s->s_hpfs_uid; |
inode | 642 | fs/hpfs/hpfs_fs.c | inode->i_gid = s->s_hpfs_gid; |
inode | 643 | fs/hpfs/hpfs_fs.c | inode->i_mode = s->s_hpfs_mode; |
inode | 644 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_conv = s->s_hpfs_conv; |
inode | 646 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dno = 0; |
inode | 647 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_n_secs = 0; |
inode | 648 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_file_sec = 0; |
inode | 649 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_disk_sec = 0; |
inode | 650 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dpos = 0; |
inode | 651 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dsubdno = 0; |
inode | 657 | fs/hpfs/hpfs_fs.c | if (ino_is_dir(inode->i_ino)) |
inode | 658 | fs/hpfs/hpfs_fs.c | inode->i_mode |= S_IFDIR; |
inode | 660 | fs/hpfs/hpfs_fs.c | inode->i_mode |= S_IFREG; |
inode | 661 | fs/hpfs/hpfs_fs.c | inode->i_mode &= ~0111; |
inode | 670 | fs/hpfs/hpfs_fs.c | inode->i_atime = 0; |
inode | 671 | fs/hpfs/hpfs_fs.c | inode->i_mtime = 0; |
inode | 672 | fs/hpfs/hpfs_fs.c | inode->i_ctime = 0; |
inode | 673 | fs/hpfs/hpfs_fs.c | inode->i_size = 0; |
inode | 679 | fs/hpfs/hpfs_fs.c | if (S_ISREG(inode->i_mode)) { |
inode | 681 | fs/hpfs/hpfs_fs.c | inode->i_op = (struct inode_operations *) &hpfs_file_iops; |
inode | 682 | fs/hpfs/hpfs_fs.c | inode->i_nlink = 1; |
inode | 683 | fs/hpfs/hpfs_fs.c | inode->i_blksize = 512; |
inode | 689 | fs/hpfs/hpfs_fs.c | struct fnode *fnode = map_fnode(inode->i_dev, |
inode | 690 | fs/hpfs/hpfs_fs.c | inode->i_ino, &bh0); |
inode | 694 | fs/hpfs/hpfs_fs.c | inode->i_mode = 0; |
inode | 698 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_parent_dir = dir_ino(fnode->up); |
inode | 699 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dno = fnode->u.external[0].disk_secno; |
inode | 704 | fs/hpfs/hpfs_fs.c | count_dnodes(inode, inode->i_hpfs_dno, &n_dnodes, &n_subdirs); |
inode | 706 | fs/hpfs/hpfs_fs.c | inode->i_op = (struct inode_operations *) &hpfs_dir_iops; |
inode | 707 | fs/hpfs/hpfs_fs.c | inode->i_blksize = 512; /* 2048 here confuses ls & du & ... */ |
inode | 708 | fs/hpfs/hpfs_fs.c | inode->i_blocks = 4 * n_dnodes; |
inode | 709 | fs/hpfs/hpfs_fs.c | inode->i_size = 512 * inode->i_blocks; |
inode | 710 | fs/hpfs/hpfs_fs.c | inode->i_nlink = 2 + n_subdirs; |
inode | 771 | fs/hpfs/hpfs_fs.c | static void count_dnodes(struct inode *inode, dnode_secno dno, |
inode | 779 | fs/hpfs/hpfs_fs.c | dnode = map_dnode(inode->i_dev, dno, &qbh); |
inode | 789 | fs/hpfs/hpfs_fs.c | count_dnodes(inode, de_down_pointer(de), |
inode | 867 | fs/hpfs/hpfs_fs.c | static int hpfs_file_read(struct inode *inode, struct file *filp, |
inode | 875 | fs/hpfs/hpfs_fs.c | if (inode == 0 || !S_ISREG(inode->i_mode)) |
inode | 881 | fs/hpfs/hpfs_fs.c | if (count > inode->i_size - (off_t) filp->f_pos) |
inode | 882 | fs/hpfs/hpfs_fs.c | count = inode->i_size - filp->f_pos; |
inode | 903 | fs/hpfs/hpfs_fs.c | block = map_sector(inode->i_dev, hpfs_bmap(inode, q), &bh); |
inode | 911 | fs/hpfs/hpfs_fs.c | if (inode->i_hpfs_conv == CONV_AUTO) |
inode | 912 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_conv = choose_conv(block + r, n); |
inode | 914 | fs/hpfs/hpfs_fs.c | if (inode->i_hpfs_conv == CONV_BINARY) { |
inode | 927 | fs/hpfs/hpfs_fs.c | if (count > inode->i_size - (off_t) filp->f_pos - n + n0) |
inode | 928 | fs/hpfs/hpfs_fs.c | count = inode->i_size - filp->f_pos - n + n0; |
inode | 998 | fs/hpfs/hpfs_fs.c | static secno hpfs_bmap(struct inode *inode, unsigned file_secno) |
inode | 1009 | fs/hpfs/hpfs_fs.c | n = file_secno - inode->i_hpfs_file_sec; |
inode | 1010 | fs/hpfs/hpfs_fs.c | if (n < inode->i_hpfs_n_secs) |
inode | 1011 | fs/hpfs/hpfs_fs.c | return inode->i_hpfs_disk_sec + n; |
inode | 1018 | fs/hpfs/hpfs_fs.c | fnode = map_fnode(inode->i_dev, inode->i_ino, &bh); |
inode | 1021 | fs/hpfs/hpfs_fs.c | disk_secno = bplus_lookup(inode, &fnode->btree, |
inode | 1035 | fs/hpfs/hpfs_fs.c | static secno bplus_lookup(struct inode *inode, struct bplus_header *b, |
inode | 1051 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_file_sec = n[i].file_secno; |
inode | 1052 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_disk_sec = n[i].disk_secno; |
inode | 1053 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_n_secs = n[i].length; |
inode | 1071 | fs/hpfs/hpfs_fs.c | anode = map_anode(inode->i_dev, ano, bhp); |
inode | 1074 | fs/hpfs/hpfs_fs.c | return bplus_lookup(inode, &anode->btree, |
inode | 1105 | fs/hpfs/hpfs_fs.c | static int hpfs_lookup(struct inode *dir, const char *name, int len, |
inode | 1106 | fs/hpfs/hpfs_fs.c | struct inode **result) |
inode | 1110 | fs/hpfs/hpfs_fs.c | struct inode *inode; |
inode | 1155 | fs/hpfs/hpfs_fs.c | if (!(inode = iget(dir->i_sb, ino))) |
inode | 1163 | fs/hpfs/hpfs_fs.c | if (!inode->i_atime) { |
inode | 1164 | fs/hpfs/hpfs_fs.c | inode->i_atime = local_to_gmt(de->read_date); |
inode | 1165 | fs/hpfs/hpfs_fs.c | inode->i_mtime = local_to_gmt(de->write_date); |
inode | 1166 | fs/hpfs/hpfs_fs.c | inode->i_ctime = local_to_gmt(de->creation_date); |
inode | 1168 | fs/hpfs/hpfs_fs.c | inode->i_mode &= ~0222; |
inode | 1170 | fs/hpfs/hpfs_fs.c | inode->i_size = de->file_size; |
inode | 1177 | fs/hpfs/hpfs_fs.c | inode->i_blocks = 1 + ((inode->i_size + 511) >> 9); |
inode | 1187 | fs/hpfs/hpfs_fs.c | *result = inode; |
inode | 1227 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_dirent(struct inode *inode, dnode_secno dno, |
inode | 1239 | fs/hpfs/hpfs_fs.c | dnode = map_dnode(inode->i_dev, dno, qbh); |
inode | 1280 | fs/hpfs/hpfs_fs.c | return map_dirent(inode, sub_dno, |
inode | 1329 | fs/hpfs/hpfs_fs.c | static int hpfs_readdir(struct inode *inode, struct file *filp, |
inode | 1337 | fs/hpfs/hpfs_fs.c | if (inode == 0 |
inode | 1338 | fs/hpfs/hpfs_fs.c | || inode->i_sb == 0 |
inode | 1339 | fs/hpfs/hpfs_fs.c | || !S_ISDIR(inode->i_mode)) |
inode | 1342 | fs/hpfs/hpfs_fs.c | lc = inode->i_sb->s_hpfs_lowercase; |
inode | 1346 | fs/hpfs/hpfs_fs.c | write_one_dirent(dirent, ".", 1, inode->i_ino, lc); |
inode | 1352 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_parent_dir, lc); |
inode | 1360 | fs/hpfs/hpfs_fs.c | de = map_pos_dirent(inode, &filp->f_pos, &qbh); |
inode | 1411 | fs/hpfs/hpfs_fs.c | static struct hpfs_dirent *map_pos_dirent(struct inode *inode, loff_t *posp, |
inode | 1431 | fs/hpfs/hpfs_fs.c | dno = dir_subdno(inode, q); |
inode | 1439 | fs/hpfs/hpfs_fs.c | de = map_nth_dirent(inode->i_dev, dno, r, qbh); |
inode | 1449 | fs/hpfs/hpfs_fs.c | return map_pos_dirent(inode, posp, qbh); |
inode | 1467 | fs/hpfs/hpfs_fs.c | return map_pos_dirent(inode, posp, qbh); |
inode | 1477 | fs/hpfs/hpfs_fs.c | static dnode_secno dir_subdno(struct inode *inode, unsigned pos) |
inode | 1487 | fs/hpfs/hpfs_fs.c | return inode->i_hpfs_dno; |
inode | 1493 | fs/hpfs/hpfs_fs.c | else if (pos == inode->i_hpfs_dpos) |
inode | 1494 | fs/hpfs/hpfs_fs.c | return inode->i_hpfs_dsubdno; |
inode | 1508 | fs/hpfs/hpfs_fs.c | dno = dir_subdno(inode, q); |
inode | 1515 | fs/hpfs/hpfs_fs.c | de = map_nth_dirent(inode->i_dev, dno, r, &qbh); |
inode | 1528 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dpos = pos; |
inode | 1529 | fs/hpfs/hpfs_fs.c | inode->i_hpfs_dsubdno = dno; |
inode | 1560 | fs/hpfs/hpfs_fs.c | static int hpfs_dir_read(struct inode *inode, struct file *filp, |
inode | 16 | fs/inode.c | struct inode * inode; |
inode | 20 | fs/inode.c | static struct inode * first_inode; |
inode | 34 | fs/inode.c | static void insert_inode_free(struct inode *inode) |
inode | 36 | fs/inode.c | inode->i_next = first_inode; |
inode | 37 | fs/inode.c | inode->i_prev = first_inode->i_prev; |
inode | 38 | fs/inode.c | inode->i_next->i_prev = inode; |
inode | 39 | fs/inode.c | inode->i_prev->i_next = inode; |
inode | 40 | fs/inode.c | first_inode = inode; |
inode | 43 | fs/inode.c | static void remove_inode_free(struct inode *inode) |
inode | 45 | fs/inode.c | if (first_inode == inode) |
inode | 47 | fs/inode.c | if (inode->i_next) |
inode | 48 | fs/inode.c | inode->i_next->i_prev = inode->i_prev; |
inode | 49 | fs/inode.c | if (inode->i_prev) |
inode | 50 | fs/inode.c | inode->i_prev->i_next = inode->i_next; |
inode | 51 | fs/inode.c | inode->i_next = inode->i_prev = NULL; |
inode | 54 | fs/inode.c | void insert_inode_hash(struct inode *inode) |
inode | 57 | fs/inode.c | h = hash(inode->i_dev, inode->i_ino); |
inode | 59 | fs/inode.c | inode->i_hash_next = h->inode; |
inode | 60 | fs/inode.c | inode->i_hash_prev = NULL; |
inode | 61 | fs/inode.c | if (inode->i_hash_next) |
inode | 62 | fs/inode.c | inode->i_hash_next->i_hash_prev = inode; |
inode | 63 | fs/inode.c | h->inode = inode; |
inode | 66 | fs/inode.c | static void remove_inode_hash(struct inode *inode) |
inode | 69 | fs/inode.c | h = hash(inode->i_dev, inode->i_ino); |
inode | 71 | fs/inode.c | if (h->inode == inode) |
inode | 72 | fs/inode.c | h->inode = inode->i_hash_next; |
inode | 73 | fs/inode.c | if (inode->i_hash_next) |
inode | 74 | fs/inode.c | inode->i_hash_next->i_hash_prev = inode->i_hash_prev; |
inode | 75 | fs/inode.c | if (inode->i_hash_prev) |
inode | 76 | fs/inode.c | inode->i_hash_prev->i_hash_next = inode->i_hash_next; |
inode | 77 | fs/inode.c | inode->i_hash_prev = inode->i_hash_next = NULL; |
inode | 80 | fs/inode.c | static void put_last_free(struct inode *inode) |
inode | 82 | fs/inode.c | remove_inode_free(inode); |
inode | 83 | fs/inode.c | inode->i_prev = first_inode->i_prev; |
inode | 84 | fs/inode.c | inode->i_prev->i_next = inode; |
inode | 85 | fs/inode.c | inode->i_next = first_inode; |
inode | 86 | fs/inode.c | inode->i_next->i_prev = inode; |
inode | 91 | fs/inode.c | struct inode * inode; |
inode | 94 | fs/inode.c | if (!(inode = (struct inode*) get_free_page(GFP_KERNEL))) |
inode | 97 | fs/inode.c | i=PAGE_SIZE / sizeof(struct inode); |
inode | 102 | fs/inode.c | inode->i_next = inode->i_prev = first_inode = inode++, i--; |
inode | 105 | fs/inode.c | insert_inode_free(inode++); |
inode | 115 | fs/inode.c | static void __wait_on_inode(struct inode *); |
inode | 117 | fs/inode.c | static inline void wait_on_inode(struct inode * inode) |
inode | 119 | fs/inode.c | if (inode->i_lock) |
inode | 120 | fs/inode.c | __wait_on_inode(inode); |
inode | 123 | fs/inode.c | static inline void lock_inode(struct inode * inode) |
inode | 125 | fs/inode.c | wait_on_inode(inode); |
inode | 126 | fs/inode.c | inode->i_lock = 1; |
inode | 129 | fs/inode.c | static inline void unlock_inode(struct inode * inode) |
inode | 131 | fs/inode.c | inode->i_lock = 0; |
inode | 132 | fs/inode.c | wake_up(&inode->i_wait); |
inode | 147 | fs/inode.c | void clear_inode(struct inode * inode) |
inode | 151 | fs/inode.c | wait_on_inode(inode); |
inode | 152 | fs/inode.c | remove_inode_hash(inode); |
inode | 153 | fs/inode.c | remove_inode_free(inode); |
inode | 154 | fs/inode.c | wait = ((volatile struct inode *) inode)->i_wait; |
inode | 155 | fs/inode.c | if (inode->i_count) |
inode | 157 | fs/inode.c | memset(inode,0,sizeof(*inode)); |
inode | 158 | fs/inode.c | ((volatile struct inode *) inode)->i_wait = wait; |
inode | 159 | fs/inode.c | insert_inode_free(inode); |
inode | 164 | fs/inode.c | struct inode * inode, * next; |
inode | 169 | fs/inode.c | inode = next; |
inode | 170 | fs/inode.c | next = inode->i_next; /* clear_inode() changes the queues.. */ |
inode | 171 | fs/inode.c | if (inode->i_dev != dev) |
inode | 173 | fs/inode.c | if (inode->i_count || inode->i_dirt || inode->i_lock) |
inode | 175 | fs/inode.c | clear_inode(inode); |
inode | 180 | fs/inode.c | int fs_may_umount(dev_t dev, struct inode * mount_root) |
inode | 182 | fs/inode.c | struct inode * inode; |
inode | 185 | fs/inode.c | inode = first_inode; |
inode | 186 | fs/inode.c | for (i=0 ; i < nr_inodes ; i++, inode = inode->i_next) { |
inode | 187 | fs/inode.c | if (inode->i_dev != dev || !inode->i_count) |
inode | 189 | fs/inode.c | if (inode == mount_root && inode->i_count == 1) |
inode | 212 | fs/inode.c | static void write_inode(struct inode * inode) |
inode | 214 | fs/inode.c | if (!inode->i_dirt) |
inode | 216 | fs/inode.c | wait_on_inode(inode); |
inode | 217 | fs/inode.c | if (!inode->i_dirt) |
inode | 219 | fs/inode.c | if (!inode->i_sb || !inode->i_sb->s_op || !inode->i_sb->s_op->write_inode) { |
inode | 220 | fs/inode.c | inode->i_dirt = 0; |
inode | 223 | fs/inode.c | inode->i_lock = 1; |
inode | 224 | fs/inode.c | inode->i_sb->s_op->write_inode(inode); |
inode | 225 | fs/inode.c | unlock_inode(inode); |
inode | 228 | fs/inode.c | static void read_inode(struct inode * inode) |
inode | 230 | fs/inode.c | lock_inode(inode); |
inode | 231 | fs/inode.c | if (inode->i_sb && inode->i_sb->s_op && inode->i_sb->s_op->read_inode) |
inode | 232 | fs/inode.c | inode->i_sb->s_op->read_inode(inode); |
inode | 233 | fs/inode.c | unlock_inode(inode); |
inode | 237 | fs/inode.c | int inode_change_ok(struct inode *inode, struct iattr *attr) |
inode | 241 | fs/inode.c | (current->fsuid != inode->i_uid || |
inode | 242 | fs/inode.c | attr->ia_uid != inode->i_uid) && !fsuser()) |
inode | 247 | fs/inode.c | (!in_group_p(attr->ia_gid) && attr->ia_gid != inode->i_gid) && |
inode | 253 | fs/inode.c | if ((current->fsuid != inode->i_uid) && !fsuser()) |
inode | 257 | fs/inode.c | inode->i_gid)) |
inode | 263 | fs/inode.c | ((current->fsuid != inode->i_uid) && !fsuser())) |
inode | 266 | fs/inode.c | ((current->fsuid != inode->i_uid) && !fsuser())) |
inode | 277 | fs/inode.c | void inode_setattr(struct inode *inode, struct iattr *attr) |
inode | 280 | fs/inode.c | inode->i_uid = attr->ia_uid; |
inode | 282 | fs/inode.c | inode->i_gid = attr->ia_gid; |
inode | 284 | fs/inode.c | inode->i_size = attr->ia_size; |
inode | 286 | fs/inode.c | inode->i_atime = attr->ia_atime; |
inode | 288 | fs/inode.c | inode->i_mtime = attr->ia_mtime; |
inode | 290 | fs/inode.c | inode->i_ctime = attr->ia_ctime; |
inode | 292 | fs/inode.c | inode->i_mode = attr->ia_mode; |
inode | 293 | fs/inode.c | if (!fsuser() && !in_group_p(inode->i_gid)) |
inode | 294 | fs/inode.c | inode->i_mode &= ~S_ISGID; |
inode | 296 | fs/inode.c | inode->i_dirt = 1; |
inode | 307 | fs/inode.c | int notify_change(struct inode * inode, struct iattr *attr) |
inode | 311 | fs/inode.c | if (inode->i_sb && inode->i_sb->s_op && |
inode | 312 | fs/inode.c | inode->i_sb->s_op->notify_change) |
inode | 313 | fs/inode.c | return inode->i_sb->s_op->notify_change(inode, attr); |
inode | 315 | fs/inode.c | if ((retval = inode_change_ok(inode, attr)) != 0) |
inode | 318 | fs/inode.c | inode_setattr(inode, attr); |
inode | 332 | fs/inode.c | int bmap(struct inode * inode, int block) |
inode | 334 | fs/inode.c | if (inode->i_op && inode->i_op->bmap) |
inode | 335 | fs/inode.c | return inode->i_op->bmap(inode,block); |
inode | 341 | fs/inode.c | struct inode * inode, * next; |
inode | 346 | fs/inode.c | inode = next; |
inode | 347 | fs/inode.c | next = inode->i_next; /* clear_inode() changes the queues.. */ |
inode | 348 | fs/inode.c | if (inode->i_dev != dev) |
inode | 350 | fs/inode.c | if (inode->i_count || inode->i_dirt || inode->i_lock) { |
inode | 354 | fs/inode.c | clear_inode(inode); |
inode | 361 | fs/inode.c | struct inode * inode; |
inode | 363 | fs/inode.c | inode = first_inode; |
inode | 364 | fs/inode.c | for(i = 0; i < nr_inodes*2; i++, inode = inode->i_next) { |
inode | 365 | fs/inode.c | if (dev && inode->i_dev != dev) |
inode | 367 | fs/inode.c | wait_on_inode(inode); |
inode | 368 | fs/inode.c | if (inode->i_dirt) |
inode | 369 | fs/inode.c | write_inode(inode); |
inode | 373 | fs/inode.c | void iput(struct inode * inode) |
inode | 375 | fs/inode.c | if (!inode) |
inode | 377 | fs/inode.c | wait_on_inode(inode); |
inode | 378 | fs/inode.c | if (!inode->i_count) { |
inode | 381 | fs/inode.c | MAJOR(inode->i_rdev), MINOR(inode->i_rdev), |
inode | 382 | fs/inode.c | inode->i_ino, inode->i_mode); |
inode | 385 | fs/inode.c | if (inode->i_pipe) |
inode | 386 | fs/inode.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 388 | fs/inode.c | if (inode->i_count>1) { |
inode | 389 | fs/inode.c | inode->i_count--; |
inode | 393 | fs/inode.c | if (inode->i_pipe) { |
inode | 394 | fs/inode.c | unsigned long page = (unsigned long) PIPE_BASE(*inode); |
inode | 395 | fs/inode.c | PIPE_BASE(*inode) = NULL; |
inode | 398 | fs/inode.c | if (inode->i_sb && inode->i_sb->s_op && inode->i_sb->s_op->put_inode) { |
inode | 399 | fs/inode.c | inode->i_sb->s_op->put_inode(inode); |
inode | 400 | fs/inode.c | if (!inode->i_nlink) |
inode | 403 | fs/inode.c | if (inode->i_dirt) { |
inode | 404 | fs/inode.c | write_inode(inode); /* we can sleep - so do again */ |
inode | 405 | fs/inode.c | wait_on_inode(inode); |
inode | 408 | fs/inode.c | inode->i_count--; |
inode | 409 | fs/inode.c | if (inode->i_mmap) { |
inode | 411 | fs/inode.c | inode->i_ino, MAJOR(inode->i_dev), MINOR(inode->i_dev)); |
inode | 412 | fs/inode.c | inode->i_mmap = NULL; |
inode | 418 | fs/inode.c | struct inode * get_empty_inode(void) |
inode | 420 | fs/inode.c | struct inode * inode, * best; |
inode | 426 | fs/inode.c | inode = first_inode; |
inode | 428 | fs/inode.c | for (i = 0; i<nr_inodes; inode = inode->i_next, i++) { |
inode | 429 | fs/inode.c | if (!inode->i_count) { |
inode | 431 | fs/inode.c | best = inode; |
inode | 432 | fs/inode.c | if (!inode->i_dirt && !inode->i_lock) { |
inode | 433 | fs/inode.c | best = inode; |
inode | 443 | fs/inode.c | inode = best; |
inode | 444 | fs/inode.c | if (!inode) { |
inode | 449 | fs/inode.c | if (inode->i_lock) { |
inode | 450 | fs/inode.c | wait_on_inode(inode); |
inode | 453 | fs/inode.c | if (inode->i_dirt) { |
inode | 454 | fs/inode.c | write_inode(inode); |
inode | 457 | fs/inode.c | if (inode->i_count) |
inode | 459 | fs/inode.c | clear_inode(inode); |
inode | 460 | fs/inode.c | inode->i_count = 1; |
inode | 461 | fs/inode.c | inode->i_nlink = 1; |
inode | 462 | fs/inode.c | inode->i_version = ++event; |
inode | 463 | fs/inode.c | inode->i_sem.count = 1; |
inode | 469 | fs/inode.c | return inode; |
inode | 472 | fs/inode.c | struct inode * get_pipe_inode(void) |
inode | 474 | fs/inode.c | struct inode * inode; |
inode | 477 | fs/inode.c | if (!(inode = get_empty_inode())) |
inode | 479 | fs/inode.c | if (!(PIPE_BASE(*inode) = (char*) __get_free_page(GFP_USER))) { |
inode | 480 | fs/inode.c | iput(inode); |
inode | 483 | fs/inode.c | inode->i_op = &pipe_inode_operations; |
inode | 484 | fs/inode.c | inode->i_count = 2; /* sum of readers/writers */ |
inode | 485 | fs/inode.c | PIPE_WAIT(*inode) = NULL; |
inode | 486 | fs/inode.c | PIPE_START(*inode) = PIPE_LEN(*inode) = 0; |
inode | 487 | fs/inode.c | PIPE_RD_OPENERS(*inode) = PIPE_WR_OPENERS(*inode) = 0; |
inode | 488 | fs/inode.c | PIPE_READERS(*inode) = PIPE_WRITERS(*inode) = 1; |
inode | 489 | fs/inode.c | PIPE_LOCK(*inode) = 0; |
inode | 490 | fs/inode.c | inode->i_pipe = 1; |
inode | 491 | fs/inode.c | inode->i_mode |= S_IFIFO | S_IRUSR | S_IWUSR; |
inode | 492 | fs/inode.c | inode->i_uid = current->fsuid; |
inode | 493 | fs/inode.c | inode->i_gid = current->fsgid; |
inode | 494 | fs/inode.c | inode->i_atime = inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 495 | fs/inode.c | inode->i_blksize = PAGE_SIZE; |
inode | 496 | fs/inode.c | return inode; |
inode | 499 | fs/inode.c | struct inode * __iget(struct super_block * sb, int nr, int crossmntp) |
inode | 503 | fs/inode.c | struct inode * inode; |
inode | 504 | fs/inode.c | struct inode * empty = NULL; |
inode | 510 | fs/inode.c | for (inode = h->inode; inode ; inode = inode->i_hash_next) |
inode | 511 | fs/inode.c | if (inode->i_dev == sb->s_dev && inode->i_ino == nr) |
inode | 522 | fs/inode.c | inode = empty; |
inode | 523 | fs/inode.c | inode->i_sb = sb; |
inode | 524 | fs/inode.c | inode->i_dev = sb->s_dev; |
inode | 525 | fs/inode.c | inode->i_ino = nr; |
inode | 526 | fs/inode.c | inode->i_flags = sb->s_flags; |
inode | 527 | fs/inode.c | put_last_free(inode); |
inode | 528 | fs/inode.c | insert_inode_hash(inode); |
inode | 529 | fs/inode.c | read_inode(inode); |
inode | 533 | fs/inode.c | if (!inode->i_count) |
inode | 535 | fs/inode.c | inode->i_count++; |
inode | 536 | fs/inode.c | wait_on_inode(inode); |
inode | 537 | fs/inode.c | if (inode->i_dev != sb->s_dev || inode->i_ino != nr) { |
inode | 539 | fs/inode.c | iput(inode); |
inode | 542 | fs/inode.c | if (crossmntp && inode->i_mount) { |
inode | 543 | fs/inode.c | struct inode * tmp = inode->i_mount; |
inode | 545 | fs/inode.c | iput(inode); |
inode | 546 | fs/inode.c | inode = tmp; |
inode | 547 | fs/inode.c | wait_on_inode(inode); |
inode | 555 | fs/inode.c | return inode; |
inode | 564 | fs/inode.c | static void __wait_on_inode(struct inode * inode) |
inode | 568 | fs/inode.c | add_wait_queue(&inode->i_wait, &wait); |
inode | 571 | fs/inode.c | if (inode->i_lock) { |
inode | 575 | fs/inode.c | remove_wait_queue(&inode->i_wait, &wait); |
inode | 32 | fs/isofs/dir.c | static int isofs_readdir(struct inode *, struct file *, struct dirent *, int); |
inode | 67 | fs/isofs/dir.c | static int isofs_readdir(struct inode * inode, struct file * filp, |
inode | 70 | fs/isofs/dir.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(inode); |
inode | 71 | fs/isofs/dir.c | unsigned char bufbits = ISOFS_BUFFER_BITS(inode); |
inode | 84 | fs/isofs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 88 | fs/isofs/dir.c | block = isofs_bmap(inode,filp->f_pos>>bufbits); |
inode | 92 | fs/isofs/dir.c | if(!(bh = breada(inode->i_dev, block, bufsize, filp->f_pos, inode->i_size))) |
inode | 95 | fs/isofs/dir.c | while (filp->f_pos < inode->i_size) { |
inode | 112 | fs/isofs/dir.c | block = isofs_bmap(inode,(filp->f_pos)>>bufbits); |
inode | 114 | fs/isofs/dir.c | || !(bh = breada(inode->i_dev, block, bufsize, filp->f_pos, |
inode | 115 | fs/isofs/dir.c | inode->i_size))) |
inode | 138 | fs/isofs/dir.c | block = isofs_bmap(inode,(filp->f_pos)>> bufbits); |
inode | 140 | fs/isofs/dir.c | || !(bh = breada(inode->i_dev, block, bufsize, |
inode | 141 | fs/isofs/dir.c | filp->f_pos, inode->i_size))) { |
inode | 154 | fs/isofs/dir.c | inode_number = inode->i_ino; |
inode | 165 | fs/isofs/dir.c | if((inode->i_sb->u.isofs_sb.s_firstdatazone) != inode->i_ino) |
inode | 166 | fs/isofs/dir.c | inode_number = inode->u.isofs_i.i_backlink; |
inode | 168 | fs/isofs/dir.c | inode_number = inode->i_ino; |
inode | 173 | fs/isofs/dir.c | isofs_lookup_grandparent(inode, |
inode | 174 | fs/isofs/dir.c | find_rock_ridge_relocation(de, inode)); |
inode | 186 | fs/isofs/dir.c | if (inode->i_sb->u.isofs_sb.s_unhide=='n') |
inode | 189 | fs/isofs/dir.c | high_sierra = inode->i_sb->u.isofs_sb.s_high_sierra; |
inode | 201 | fs/isofs/dir.c | rrflag = get_rock_ridge_filename(de, &dpnt, &dlen, inode); |
inode | 213 | fs/isofs/dir.c | if(inode->i_sb->u.isofs_sb.s_mapping == 'n') { |
inode | 235 | fs/isofs/dir.c | dcache_add(inode, dpnt, i, inode_number); |
inode | 36 | fs/isofs/file.c | static int isofs_file_read(struct inode *, struct file *, char *, int); |
inode | 98 | fs/isofs/file.c | static void isofs_determine_filetype(struct inode * inode) |
inode | 105 | fs/isofs/file.c | block = isofs_bmap(inode,0); |
inode | 106 | fs/isofs/file.c | if (block && (bh = bread(inode->i_dev,block, ISOFS_BUFFER_SIZE(inode)))) { |
inode | 109 | fs/isofs/file.c | for(i=0;i<(inode->i_size < ISOFS_BUFFER_SIZE(inode) ? inode->i_size : ISOFS_BUFFER_SIZE(inode)); |
inode | 119 | fs/isofs/file.c | inode->u.isofs_i.i_file_format = result; |
inode | 123 | fs/isofs/file.c | static int isofs_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 133 | fs/isofs/file.c | if (!inode) { |
inode | 137 | fs/isofs/file.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode))) { |
inode | 138 | fs/isofs/file.c | printk("isofs_file_read: mode = %07o\n",inode->i_mode); |
inode | 141 | fs/isofs/file.c | if (inode->u.isofs_i.i_file_format == ISOFS_FILE_UNKNOWN) |
inode | 142 | fs/isofs/file.c | isofs_determine_filetype(inode); |
inode | 143 | fs/isofs/file.c | if (filp->f_pos > inode->i_size) |
inode | 146 | fs/isofs/file.c | left = inode->i_size - filp->f_pos; |
inode | 152 | fs/isofs/file.c | block = filp->f_pos >> ISOFS_BUFFER_BITS(inode); |
inode | 153 | fs/isofs/file.c | offset = (inode->u.isofs_i.i_first_extent + filp->f_pos) |
inode | 154 | fs/isofs/file.c | & (ISOFS_BUFFER_SIZE(inode)-1); |
inode | 155 | fs/isofs/file.c | blocks = (left + offset + ISOFS_BUFFER_SIZE(inode) - 1) / ISOFS_BUFFER_SIZE(inode); |
inode | 158 | fs/isofs/file.c | ra_blocks = read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9); |
inode | 168 | fs/isofs/file.c | total_blocks = (inode->i_size + (1 << ISOFS_BUFFER_BITS(inode)) - 1) |
inode | 169 | fs/isofs/file.c | >> ISOFS_BUFFER_BITS(inode); |
inode | 173 | fs/isofs/file.c | max_block = (inode->i_size + BLOCK_SIZE - 1)/BLOCK_SIZE; |
inode | 191 | fs/isofs/file.c | *bhb = getblk(inode->i_dev,isofs_bmap(inode, block++), ISOFS_BUFFER_SIZE(inode)); |
inode | 225 | fs/isofs/file.c | if (left < ISOFS_BUFFER_SIZE(inode) - offset) |
inode | 228 | fs/isofs/file.c | chars = ISOFS_BUFFER_SIZE(inode) - offset; |
inode | 233 | fs/isofs/file.c | if (inode->u.isofs_i.i_file_format == ISOFS_FILE_TEXT || |
inode | 234 | fs/isofs/file.c | inode->u.isofs_i.i_file_format == ISOFS_FILE_TEXT_M) |
inode | 236 | fs/isofs/file.c | inode->u.isofs_i.i_file_format); |
inode | 159 | fs/isofs/inode.c | struct inode inode_fake; |
inode | 407 | fs/isofs/inode.c | int isofs_bmap(struct inode * inode,int block) |
inode | 414 | fs/isofs/inode.c | return (inode->u.isofs_i.i_first_extent >> ISOFS_BUFFER_BITS(inode)) + block; |
inode | 417 | fs/isofs/inode.c | void isofs_read_inode(struct inode * inode) |
inode | 419 | fs/isofs/inode.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(inode); |
inode | 428 | fs/isofs/inode.c | block = inode->i_ino >> ISOFS_BUFFER_BITS(inode); |
inode | 429 | fs/isofs/inode.c | if (!(bh=bread(inode->i_dev,block, bufsize))) { |
inode | 435 | fs/isofs/inode.c | + (inode->i_ino & (bufsize - 1))); |
inode | 437 | fs/isofs/inode.c | high_sierra = inode->i_sb->u.isofs_sb.s_high_sierra; |
inode | 439 | fs/isofs/inode.c | if ((inode->i_ino & (bufsize - 1)) + *pnt > bufsize){ |
inode | 442 | fs/isofs/inode.c | offset = (inode->i_ino & (bufsize - 1)); |
inode | 446 | fs/isofs/inode.c | printk(KERN_INFO "NoMem ISO inode %lu\n",inode->i_ino); |
inode | 452 | fs/isofs/inode.c | if (!(bh = bread(inode->i_dev,++block, bufsize))) { |
inode | 464 | fs/isofs/inode.c | inode->i_mode = S_IRUGO | S_IXUGO | S_IFDIR; |
inode | 465 | fs/isofs/inode.c | inode->i_nlink = 1; /* Set to 1. We know there are 2, but |
inode | 471 | fs/isofs/inode.c | inode->i_mode = inode->i_sb->u.isofs_sb.s_mode; /* Everybody gets to read the file. */ |
inode | 472 | fs/isofs/inode.c | inode->i_nlink = 1; |
inode | 473 | fs/isofs/inode.c | inode->i_mode |= S_IFREG; |
inode | 479 | fs/isofs/inode.c | inode->i_mode |= S_IXUGO; /* execute permission */ |
inode | 481 | fs/isofs/inode.c | inode->i_uid = inode->i_sb->u.isofs_sb.s_uid; |
inode | 482 | fs/isofs/inode.c | inode->i_gid = inode->i_sb->u.isofs_sb.s_gid; |
inode | 483 | fs/isofs/inode.c | inode->i_size = isonum_733 (raw_inode->size); |
inode | 487 | fs/isofs/inode.c | if((inode->i_size < 0 || inode->i_size > 700000000) && |
inode | 488 | fs/isofs/inode.c | inode->i_sb->u.isofs_sb.s_cruft == 'n') { |
inode | 490 | fs/isofs/inode.c | inode->i_sb->u.isofs_sb.s_cruft = 'y'; |
inode | 497 | fs/isofs/inode.c | if(inode->i_sb->u.isofs_sb.s_cruft == 'y' && |
inode | 498 | fs/isofs/inode.c | inode->i_size & 0xff000000){ |
inode | 500 | fs/isofs/inode.c | inode->i_size &= 0x00ffffff; |
inode | 505 | fs/isofs/inode.c | inode->i_size = 0; |
inode | 511 | fs/isofs/inode.c | printk("File unit size != 0 for ISO file (%ld).\n",inode->i_ino); |
inode | 519 | fs/isofs/inode.c | inode->i_ino, raw_inode->flags[-high_sierra]); |
inode | 524 | fs/isofs/inode.c | printk("Get inode %d: %d %d: %d\n",inode->i_ino, block, |
inode | 525 | fs/isofs/inode.c | ((int)pnt) & 0x3ff, inode->i_size); |
inode | 528 | fs/isofs/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = |
inode | 531 | fs/isofs/inode.c | inode->u.isofs_i.i_first_extent = (isonum_733 (raw_inode->extent) + |
inode | 533 | fs/isofs/inode.c | << inode -> i_sb -> u.isofs_sb.s_log_zone_size; |
inode | 535 | fs/isofs/inode.c | inode->u.isofs_i.i_backlink = 0xffffffff; /* Will be used for previous directory */ |
inode | 536 | fs/isofs/inode.c | switch (inode->i_sb->u.isofs_sb.s_conversion){ |
inode | 538 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_UNKNOWN; /* File type */ |
inode | 541 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_BINARY; /* File type */ |
inode | 544 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_TEXT; /* File type */ |
inode | 547 | fs/isofs/inode.c | inode->u.isofs_i.i_file_format = ISOFS_FILE_TEXT_M; /* File type */ |
inode | 555 | fs/isofs/inode.c | parse_rock_ridge_inode(raw_inode, inode); |
inode | 558 | fs/isofs/inode.c | printk("Inode: %x extent: %x\n",inode->i_ino, inode->u.isofs_i.i_first_extent); |
inode | 562 | fs/isofs/inode.c | inode->i_op = NULL; |
inode | 566 | fs/isofs/inode.c | if (inode->i_sb->u.isofs_sb.s_cruft == 'n' && |
inode | 569 | fs/isofs/inode.c | inode->i_sb->u.isofs_sb.s_cruft = 'y'; |
inode | 572 | fs/isofs/inode.c | if (inode->i_sb->u.isofs_sb.s_cruft != 'y' && |
inode | 576 | fs/isofs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 577 | fs/isofs/inode.c | inode->i_op = &isofs_file_inode_operations; |
inode | 578 | fs/isofs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 579 | fs/isofs/inode.c | inode->i_op = &isofs_dir_inode_operations; |
inode | 580 | fs/isofs/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 581 | fs/isofs/inode.c | inode->i_op = &isofs_symlink_inode_operations; |
inode | 582 | fs/isofs/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 583 | fs/isofs/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 584 | fs/isofs/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 585 | fs/isofs/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 586 | fs/isofs/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 587 | fs/isofs/inode.c | init_fifo(inode); |
inode | 596 | fs/isofs/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = 0; |
inode | 597 | fs/isofs/inode.c | inode->u.isofs_i.i_first_extent = 0; |
inode | 598 | fs/isofs/inode.c | inode->u.isofs_i.i_backlink = 0xffffffff; |
inode | 599 | fs/isofs/inode.c | inode->i_size = 0; |
inode | 600 | fs/isofs/inode.c | inode->i_nlink = 1; |
inode | 601 | fs/isofs/inode.c | inode->i_uid = inode->i_gid = 0; |
inode | 602 | fs/isofs/inode.c | inode->i_mode = S_IFREG; /*Regular file, no one gets to read*/ |
inode | 603 | fs/isofs/inode.c | inode->i_op = NULL; |
inode | 626 | fs/isofs/inode.c | int isofs_lookup_grandparent(struct inode * parent, int extent) |
inode | 65 | fs/isofs/namei.c | static struct buffer_head * isofs_find_entry(struct inode * dir, |
inode | 212 | fs/isofs/namei.c | int isofs_lookup(struct inode * dir,const char * name, int len, |
inode | 213 | fs/isofs/namei.c | struct inode ** result) |
inode | 101 | fs/isofs/rock.c | struct inode * inode) { |
inode | 116 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) return retval; |
inode | 166 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat, inode); |
inode | 174 | fs/isofs/rock.c | char ** name, int * namlen, struct inode * inode) |
inode | 182 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) return 0; |
inode | 234 | fs/isofs/rock.c | printk("RR: RE (%x)\n", inode->i_ino); |
inode | 244 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat,inode); |
inode | 258 | fs/isofs/rock.c | struct inode * inode){ |
inode | 263 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) return 0; |
inode | 269 | fs/isofs/rock.c | struct inode * reloc; |
inode | 299 | fs/isofs/rock.c | inode->i_mode = isonum_733(rr->u.PX.mode); |
inode | 300 | fs/isofs/rock.c | inode->i_nlink = isonum_733(rr->u.PX.n_links); |
inode | 301 | fs/isofs/rock.c | inode->i_uid = isonum_733(rr->u.PX.uid); |
inode | 302 | fs/isofs/rock.c | inode->i_gid = isonum_733(rr->u.PX.gid); |
inode | 316 | fs/isofs/rock.c | inode->i_rdev = low; |
inode | 318 | fs/isofs/rock.c | inode->i_rdev = MKDEV(high, low); |
inode | 327 | fs/isofs/rock.c | inode->i_ctime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 329 | fs/isofs/rock.c | inode->i_mtime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 331 | fs/isofs/rock.c | inode->i_atime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 333 | fs/isofs/rock.c | inode->i_ctime = iso_date(rr->u.TF.times[cnt++].time, 0); |
inode | 340 | fs/isofs/rock.c | inode->i_size = 0; |
inode | 345 | fs/isofs/rock.c | inode->i_size += slp->len; |
inode | 348 | fs/isofs/rock.c | inode->i_size += 1; |
inode | 351 | fs/isofs/rock.c | inode->i_size += 2; |
inode | 355 | fs/isofs/rock.c | inode->i_size += 1; |
inode | 364 | fs/isofs/rock.c | if(!rootflag) inode->i_size += 1; |
inode | 373 | fs/isofs/rock.c | printk("RR CL (%x)\n",inode->i_ino); |
inode | 375 | fs/isofs/rock.c | inode->u.isofs_i.i_first_extent = isonum_733(rr->u.CL.location) << |
inode | 376 | fs/isofs/rock.c | inode -> i_sb -> u.isofs_sb.s_log_zone_size; |
inode | 377 | fs/isofs/rock.c | reloc = iget(inode->i_sb, inode->u.isofs_i.i_first_extent); |
inode | 378 | fs/isofs/rock.c | inode->i_mode = reloc->i_mode; |
inode | 379 | fs/isofs/rock.c | inode->i_nlink = reloc->i_nlink; |
inode | 380 | fs/isofs/rock.c | inode->i_uid = reloc->i_uid; |
inode | 381 | fs/isofs/rock.c | inode->i_gid = reloc->i_gid; |
inode | 382 | fs/isofs/rock.c | inode->i_rdev = reloc->i_rdev; |
inode | 383 | fs/isofs/rock.c | inode->i_size = reloc->i_size; |
inode | 384 | fs/isofs/rock.c | inode->i_atime = reloc->i_atime; |
inode | 385 | fs/isofs/rock.c | inode->i_ctime = reloc->i_ctime; |
inode | 386 | fs/isofs/rock.c | inode->i_mtime = reloc->i_mtime; |
inode | 394 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat,inode); |
inode | 405 | fs/isofs/rock.c | char * get_rock_ridge_symlink(struct inode * inode) |
inode | 407 | fs/isofs/rock.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(inode); |
inode | 408 | fs/isofs/rock.c | unsigned char bufbits = ISOFS_BUFFER_BITS(inode); |
inode | 422 | fs/isofs/rock.c | if (!inode->i_sb->u.isofs_sb.s_rock) |
inode | 427 | fs/isofs/rock.c | block = inode->i_ino >> bufbits; |
inode | 428 | fs/isofs/rock.c | if (!(bh=bread(inode->i_dev,block, bufsize))) { |
inode | 433 | fs/isofs/rock.c | pnt = ((unsigned char *) bh->b_data) + (inode->i_ino & (bufsize - 1)); |
inode | 437 | fs/isofs/rock.c | if ((inode->i_ino & (bufsize - 1)) + *pnt > bufsize){ |
inode | 440 | fs/isofs/rock.c | offset = (inode->i_ino & (bufsize - 1)); |
inode | 446 | fs/isofs/rock.c | if (!(bh = bread(inode->i_dev,++block, bufsize))) { |
inode | 485 | fs/isofs/rock.c | rpnt = (char *) kmalloc (inode->i_size +1, GFP_KERNEL); |
inode | 519 | fs/isofs/rock.c | MAYBE_CONTINUE(repeat,inode); |
inode | 25 | fs/isofs/symlink.c | static int isofs_readlink(struct inode *, char *, int); |
inode | 26 | fs/isofs/symlink.c | static int isofs_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 49 | fs/isofs/symlink.c | static int isofs_follow_link(struct inode * dir, struct inode * inode, |
inode | 50 | fs/isofs/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 59 | fs/isofs/symlink.c | if (!inode) { |
inode | 64 | fs/isofs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 66 | fs/isofs/symlink.c | *res_inode = inode; |
inode | 70 | fs/isofs/symlink.c | !(pnt = get_rock_ridge_symlink(inode))) { |
inode | 72 | fs/isofs/symlink.c | iput(inode); |
inode | 76 | fs/isofs/symlink.c | iput(inode); |
inode | 84 | fs/isofs/symlink.c | static int isofs_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 90 | fs/isofs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 91 | fs/isofs/symlink.c | iput(inode); |
inode | 97 | fs/isofs/symlink.c | pnt = get_rock_ridge_symlink(inode); |
inode | 99 | fs/isofs/symlink.c | iput(inode); |
inode | 125 | fs/minix/bitmap.c | void minix_free_inode(struct inode * inode) |
inode | 130 | fs/minix/bitmap.c | if (!inode) |
inode | 132 | fs/minix/bitmap.c | if (!inode->i_dev) { |
inode | 136 | fs/minix/bitmap.c | if (inode->i_count != 1) { |
inode | 137 | fs/minix/bitmap.c | printk("free_inode: inode has count=%d\n",inode->i_count); |
inode | 140 | fs/minix/bitmap.c | if (inode->i_nlink) { |
inode | 141 | fs/minix/bitmap.c | printk("free_inode: inode has nlink=%d\n",inode->i_nlink); |
inode | 144 | fs/minix/bitmap.c | if (!inode->i_sb) { |
inode | 148 | fs/minix/bitmap.c | if (inode->i_ino < 1 || inode->i_ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 152 | fs/minix/bitmap.c | ino = inode->i_ino; |
inode | 153 | fs/minix/bitmap.c | if (!(bh=inode->i_sb->u.minix_sb.s_imap[ino >> 13])) { |
inode | 157 | fs/minix/bitmap.c | clear_inode(inode); |
inode | 163 | fs/minix/bitmap.c | struct inode * minix_new_inode(const struct inode * dir) |
inode | 166 | fs/minix/bitmap.c | struct inode * inode; |
inode | 170 | fs/minix/bitmap.c | if (!dir || !(inode = get_empty_inode())) |
inode | 173 | fs/minix/bitmap.c | inode->i_sb = sb; |
inode | 174 | fs/minix/bitmap.c | inode->i_flags = inode->i_sb->s_flags; |
inode | 177 | fs/minix/bitmap.c | if ((bh = inode->i_sb->u.minix_sb.s_imap[i]) != NULL) |
inode | 181 | fs/minix/bitmap.c | iput(inode); |
inode | 186 | fs/minix/bitmap.c | iput(inode); |
inode | 191 | fs/minix/bitmap.c | if (!j || j >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 192 | fs/minix/bitmap.c | iput(inode); |
inode | 195 | fs/minix/bitmap.c | inode->i_count = 1; |
inode | 196 | fs/minix/bitmap.c | inode->i_nlink = 1; |
inode | 197 | fs/minix/bitmap.c | inode->i_dev = sb->s_dev; |
inode | 198 | fs/minix/bitmap.c | inode->i_uid = current->fsuid; |
inode | 199 | fs/minix/bitmap.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 200 | fs/minix/bitmap.c | inode->i_dirt = 1; |
inode | 201 | fs/minix/bitmap.c | inode->i_ino = j; |
inode | 202 | fs/minix/bitmap.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 203 | fs/minix/bitmap.c | inode->i_op = NULL; |
inode | 204 | fs/minix/bitmap.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 205 | fs/minix/bitmap.c | insert_inode_hash(inode); |
inode | 206 | fs/minix/bitmap.c | return inode; |
inode | 23 | fs/minix/dir.c | static int minix_dir_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 28 | fs/minix/dir.c | static int minix_readdir(struct inode *, struct file *, struct dirent *, int); |
inode | 64 | fs/minix/dir.c | static int minix_readdir(struct inode * inode, struct file * filp, |
inode | 74 | fs/minix/dir.c | if (!inode || !inode->i_sb || !S_ISDIR(inode->i_mode)) |
inode | 76 | fs/minix/dir.c | info = &inode->i_sb->u.minix_sb; |
inode | 80 | fs/minix/dir.c | while (!ret && filp->f_pos < inode->i_size) { |
inode | 82 | fs/minix/dir.c | bh = minix_bread(inode,(filp->f_pos)>>BLOCK_SIZE_BITS,0); |
inode | 87 | fs/minix/dir.c | while (!ret && offset < 1024 && filp->f_pos < inode->i_size) { |
inode | 92 | fs/minix/dir.c | if (de->inode) { |
inode | 93 | fs/minix/dir.c | version = inode->i_version; |
inode | 100 | fs/minix/dir.c | put_fs_long(de->inode,&dirent->d_ino); |
inode | 103 | fs/minix/dir.c | if (version != inode->i_version) |
inode | 32 | fs/minix/file.c | static int minix_file_read(struct inode *, struct file *, char *, int); |
inode | 33 | fs/minix/file.c | static int minix_file_write(struct inode *, struct file *, char *, int); |
inode | 70 | fs/minix/file.c | static int minix_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 80 | fs/minix/file.c | if (!inode) { |
inode | 84 | fs/minix/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 85 | fs/minix/file.c | printk("minix_file_read: mode = %07o\n",inode->i_mode); |
inode | 89 | fs/minix/file.c | size = inode->i_size; |
inode | 105 | fs/minix/file.c | if(blocks < read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9)) |
inode | 106 | fs/minix/file.c | blocks = read_ahead[MAJOR(inode->i_dev)] / (BLOCK_SIZE >> 9); |
inode | 126 | fs/minix/file.c | *bhb = minix_getblk(inode, block++, 0); |
inode | 188 | fs/minix/file.c | if (!IS_RDONLY(inode)) |
inode | 189 | fs/minix/file.c | inode->i_atime = CURRENT_TIME; |
inode | 193 | fs/minix/file.c | static int minix_file_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 200 | fs/minix/file.c | if (!inode) { |
inode | 204 | fs/minix/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 205 | fs/minix/file.c | printk("minix_file_write: mode = %07o\n",inode->i_mode); |
inode | 208 | fs/minix/file.c | down(&inode->i_sem); |
inode | 210 | fs/minix/file.c | pos = inode->i_size; |
inode | 215 | fs/minix/file.c | bh = minix_getblk(inode,pos/BLOCK_SIZE,1); |
inode | 243 | fs/minix/file.c | if (pos > inode->i_size) |
inode | 244 | fs/minix/file.c | inode->i_size = pos; |
inode | 245 | fs/minix/file.c | up(&inode->i_sem); |
inode | 246 | fs/minix/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 248 | fs/minix/file.c | inode->i_dirt = 1; |
inode | 31 | fs/minix/fsync.c | static int 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 sync_iblock (struct inode * inode, unsigned short * iblock, |
inode | 70 | fs/minix/fsync.c | rc = sync_block (inode, iblock, wait); |
inode | 73 | fs/minix/fsync.c | *bh = bread(inode->i_dev, tmp, blocksize); |
inode | 85 | fs/minix/fsync.c | static int sync_direct(struct inode *inode, int wait) |
inode | 91 | fs/minix/fsync.c | rc = sync_block (inode, inode->u.minix_i.i_data + i, wait); |
inode | 100 | fs/minix/fsync.c | static int sync_indirect(struct inode *inode, unsigned short *iblock, int wait) |
inode | 106 | fs/minix/fsync.c | rc = sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 111 | fs/minix/fsync.c | rc = sync_block (inode, |
inode | 123 | fs/minix/fsync.c | static int sync_dindirect(struct inode *inode, unsigned short *diblock, |
inode | 130 | fs/minix/fsync.c | rc = sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 135 | fs/minix/fsync.c | rc = sync_indirect (inode, |
inode | 147 | fs/minix/fsync.c | int 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 |= sync_direct(inode, wait); |
inode | 158 | fs/minix/fsync.c | err |= sync_indirect(inode, inode->u.minix_i.i_data+7, wait); |
inode | 159 | fs/minix/fsync.c | err |= sync_dindirect(inode, inode->u.minix_i.i_data+8, wait); |
inode | 161 | fs/minix/fsync.c | err |= minix_sync_inode (inode); |
inode | 27 | fs/minix/inode.c | void minix_put_inode(struct inode *inode) |
inode | 29 | fs/minix/inode.c | if (inode->i_nlink) |
inode | 31 | fs/minix/inode.c | inode->i_size = 0; |
inode | 32 | fs/minix/inode.c | minix_truncate(inode); |
inode | 33 | fs/minix/inode.c | minix_free_inode(inode); |
inode | 245 | fs/minix/inode.c | #define inode_bmap(inode,nr) ((inode)->u.minix_i.i_data[(nr)]) |
inode | 258 | fs/minix/inode.c | int minix_bmap(struct inode * inode,int block) |
inode | 271 | fs/minix/inode.c | return inode_bmap(inode,block); |
inode | 274 | fs/minix/inode.c | i = inode_bmap(inode,7); |
inode | 277 | fs/minix/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block); |
inode | 280 | fs/minix/inode.c | i = inode_bmap(inode,8); |
inode | 283 | fs/minix/inode.c | i = block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block>>9); |
inode | 286 | fs/minix/inode.c | return block_bmap(bread(inode->i_dev,i,BLOCK_SIZE),block & 511); |
inode | 289 | fs/minix/inode.c | static struct buffer_head * inode_getblk(struct inode * inode, int nr, int create) |
inode | 295 | fs/minix/inode.c | p = inode->u.minix_i.i_data + nr; |
inode | 299 | fs/minix/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 307 | fs/minix/inode.c | tmp = minix_new_block(inode->i_sb); |
inode | 310 | fs/minix/inode.c | result = getblk(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 312 | fs/minix/inode.c | minix_free_block(inode->i_sb,tmp); |
inode | 317 | fs/minix/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 318 | fs/minix/inode.c | inode->i_dirt = 1; |
inode | 322 | fs/minix/inode.c | static struct buffer_head * block_getblk(struct inode * inode, |
inode | 355 | fs/minix/inode.c | tmp = minix_new_block(inode->i_sb); |
inode | 362 | fs/minix/inode.c | minix_free_block(inode->i_sb,tmp); |
inode | 372 | fs/minix/inode.c | struct buffer_head * minix_getblk(struct inode * inode, int block, int create) |
inode | 385 | fs/minix/inode.c | return inode_getblk(inode,block,create); |
inode | 388 | fs/minix/inode.c | bh = inode_getblk(inode,7,create); |
inode | 389 | fs/minix/inode.c | return block_getblk(inode, bh, block, create); |
inode | 392 | fs/minix/inode.c | bh = inode_getblk(inode,8,create); |
inode | 393 | fs/minix/inode.c | bh = block_getblk(inode, bh, block>>9, create); |
inode | 394 | fs/minix/inode.c | return block_getblk(inode, bh, block & 511, create); |
inode | 397 | fs/minix/inode.c | struct buffer_head * minix_bread(struct inode * inode, int block, int create) |
inode | 401 | fs/minix/inode.c | bh = minix_getblk(inode,block,create); |
inode | 412 | fs/minix/inode.c | void minix_read_inode(struct inode * inode) |
inode | 418 | fs/minix/inode.c | ino = inode->i_ino; |
inode | 419 | fs/minix/inode.c | inode->i_op = NULL; |
inode | 420 | fs/minix/inode.c | inode->i_mode = 0; |
inode | 421 | fs/minix/inode.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 423 | fs/minix/inode.c | inode->i_dev, ino); |
inode | 426 | fs/minix/inode.c | block = 2 + inode->i_sb->u.minix_sb.s_imap_blocks + |
inode | 427 | fs/minix/inode.c | inode->i_sb->u.minix_sb.s_zmap_blocks + |
inode | 429 | fs/minix/inode.c | if (!(bh=bread(inode->i_dev,block, BLOCK_SIZE))) { |
inode | 431 | fs/minix/inode.c | inode->i_dev); |
inode | 436 | fs/minix/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 437 | fs/minix/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 438 | fs/minix/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 439 | fs/minix/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 440 | fs/minix/inode.c | inode->i_size = raw_inode->i_size; |
inode | 441 | fs/minix/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = raw_inode->i_time; |
inode | 442 | fs/minix/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 443 | fs/minix/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 444 | fs/minix/inode.c | inode->i_rdev = raw_inode->i_zone[0]; |
inode | 446 | fs/minix/inode.c | inode->u.minix_i.i_data[block] = raw_inode->i_zone[block]; |
inode | 448 | fs/minix/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 449 | fs/minix/inode.c | inode->i_op = &minix_file_inode_operations; |
inode | 450 | fs/minix/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 451 | fs/minix/inode.c | inode->i_op = &minix_dir_inode_operations; |
inode | 452 | fs/minix/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 453 | fs/minix/inode.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 454 | fs/minix/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 455 | fs/minix/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 456 | fs/minix/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 457 | fs/minix/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 458 | fs/minix/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 459 | fs/minix/inode.c | init_fifo(inode); |
inode | 462 | fs/minix/inode.c | static struct buffer_head * minix_update_inode(struct inode * inode) |
inode | 468 | fs/minix/inode.c | ino = inode->i_ino; |
inode | 469 | fs/minix/inode.c | if (!ino || ino >= inode->i_sb->u.minix_sb.s_ninodes) { |
inode | 471 | fs/minix/inode.c | inode->i_dev, ino); |
inode | 472 | fs/minix/inode.c | inode->i_dirt = 0; |
inode | 475 | 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 | 477 | fs/minix/inode.c | if (!(bh=bread(inode->i_dev, block, BLOCK_SIZE))) { |
inode | 479 | fs/minix/inode.c | inode->i_dirt = 0; |
inode | 484 | fs/minix/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 485 | fs/minix/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 486 | fs/minix/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 487 | fs/minix/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 488 | fs/minix/inode.c | raw_inode->i_size = inode->i_size; |
inode | 489 | fs/minix/inode.c | raw_inode->i_time = inode->i_mtime; |
inode | 490 | fs/minix/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 491 | fs/minix/inode.c | raw_inode->i_zone[0] = inode->i_rdev; |
inode | 493 | fs/minix/inode.c | raw_inode->i_zone[block] = inode->u.minix_i.i_data[block]; |
inode | 494 | fs/minix/inode.c | inode->i_dirt=0; |
inode | 499 | fs/minix/inode.c | void minix_write_inode(struct inode * inode) |
inode | 502 | fs/minix/inode.c | bh = minix_update_inode(inode); |
inode | 506 | fs/minix/inode.c | int minix_sync_inode(struct inode * inode) |
inode | 511 | fs/minix/inode.c | bh = minix_update_inode(inode); |
inode | 519 | fs/minix/inode.c | inode->i_dev, inode->i_ino); |
inode | 52 | fs/minix/namei.c | if (!de->inode || len > info->s_namelen) |
inode | 68 | fs/minix/namei.c | static struct buffer_head * minix_find_entry(struct inode * dir, |
inode | 111 | fs/minix/namei.c | int minix_lookup(struct inode * dir,const char * name, int len, |
inode | 112 | fs/minix/namei.c | struct inode ** result) |
inode | 129 | fs/minix/namei.c | ino = de->inode; |
inode | 149 | fs/minix/namei.c | static int minix_add_entry(struct inode * dir, |
inode | 185 | fs/minix/namei.c | de->inode = 0; |
inode | 189 | fs/minix/namei.c | if (de->inode) { |
inode | 215 | fs/minix/namei.c | int minix_create(struct inode * dir,const char * name, int len, int mode, |
inode | 216 | fs/minix/namei.c | struct inode ** result) |
inode | 219 | fs/minix/namei.c | struct inode * inode; |
inode | 226 | fs/minix/namei.c | inode = minix_new_inode(dir); |
inode | 227 | fs/minix/namei.c | if (!inode) { |
inode | 231 | fs/minix/namei.c | inode->i_op = &minix_file_inode_operations; |
inode | 232 | fs/minix/namei.c | inode->i_mode = mode; |
inode | 233 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 236 | fs/minix/namei.c | inode->i_nlink--; |
inode | 237 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 238 | fs/minix/namei.c | iput(inode); |
inode | 242 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 246 | fs/minix/namei.c | *result = inode; |
inode | 250 | fs/minix/namei.c | int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
inode | 253 | fs/minix/namei.c | struct inode * inode; |
inode | 265 | fs/minix/namei.c | inode = minix_new_inode(dir); |
inode | 266 | fs/minix/namei.c | if (!inode) { |
inode | 270 | fs/minix/namei.c | inode->i_uid = current->fsuid; |
inode | 271 | fs/minix/namei.c | inode->i_mode = mode; |
inode | 272 | fs/minix/namei.c | inode->i_op = NULL; |
inode | 273 | fs/minix/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 274 | fs/minix/namei.c | inode->i_op = &minix_file_inode_operations; |
inode | 275 | fs/minix/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 276 | fs/minix/namei.c | inode->i_op = &minix_dir_inode_operations; |
inode | 278 | fs/minix/namei.c | inode->i_mode |= S_ISGID; |
inode | 280 | fs/minix/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 281 | fs/minix/namei.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 282 | fs/minix/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 283 | fs/minix/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 284 | fs/minix/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 285 | fs/minix/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 286 | fs/minix/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 287 | fs/minix/namei.c | init_fifo(inode); |
inode | 289 | fs/minix/namei.c | inode->i_rdev = rdev; |
inode | 290 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 293 | fs/minix/namei.c | inode->i_nlink--; |
inode | 294 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 295 | fs/minix/namei.c | iput(inode); |
inode | 299 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 303 | fs/minix/namei.c | iput(inode); |
inode | 307 | fs/minix/namei.c | int minix_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 310 | fs/minix/namei.c | struct inode * inode; |
inode | 330 | fs/minix/namei.c | inode = minix_new_inode(dir); |
inode | 331 | fs/minix/namei.c | if (!inode) { |
inode | 335 | fs/minix/namei.c | inode->i_op = &minix_dir_inode_operations; |
inode | 336 | fs/minix/namei.c | inode->i_size = 2 * info->s_dirsize; |
inode | 337 | fs/minix/namei.c | dir_block = minix_bread(inode,0,1); |
inode | 340 | fs/minix/namei.c | inode->i_nlink--; |
inode | 341 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 342 | fs/minix/namei.c | iput(inode); |
inode | 346 | fs/minix/namei.c | de->inode=inode->i_ino; |
inode | 349 | fs/minix/namei.c | de->inode = dir->i_ino; |
inode | 351 | fs/minix/namei.c | inode->i_nlink = 2; |
inode | 354 | fs/minix/namei.c | inode->i_mode = S_IFDIR | (mode & 0777 & ~current->fs->umask); |
inode | 356 | fs/minix/namei.c | inode->i_mode |= S_ISGID; |
inode | 357 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 361 | fs/minix/namei.c | inode->i_nlink=0; |
inode | 362 | fs/minix/namei.c | iput(inode); |
inode | 365 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 370 | fs/minix/namei.c | iput(inode); |
inode | 378 | fs/minix/namei.c | static int empty_dir(struct inode * inode) |
inode | 385 | fs/minix/namei.c | if (!inode || !inode->i_sb) |
inode | 387 | fs/minix/namei.c | info = &inode->i_sb->u.minix_sb; |
inode | 391 | fs/minix/namei.c | if (inode->i_size & (info->s_dirsize-1)) |
inode | 393 | fs/minix/namei.c | if (inode->i_size < offset) |
inode | 395 | fs/minix/namei.c | bh = minix_bread(inode,0,0); |
inode | 399 | fs/minix/namei.c | if (!de->inode || strcmp(de->name,".")) |
inode | 402 | fs/minix/namei.c | if (!de->inode || strcmp(de->name,"..")) |
inode | 404 | fs/minix/namei.c | while (block*BLOCK_SIZE+offset < inode->i_size) { |
inode | 406 | fs/minix/namei.c | bh = minix_bread(inode,block,0); |
inode | 414 | fs/minix/namei.c | if (de->inode) { |
inode | 429 | fs/minix/namei.c | printk("Bad directory on device %04x\n",inode->i_dev); |
inode | 433 | fs/minix/namei.c | int minix_rmdir(struct inode * dir, const char * name, int len) |
inode | 436 | fs/minix/namei.c | struct inode * inode; |
inode | 440 | fs/minix/namei.c | inode = NULL; |
inode | 446 | fs/minix/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 449 | fs/minix/namei.c | current->fsuid != inode->i_uid && |
inode | 452 | fs/minix/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 454 | fs/minix/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 456 | fs/minix/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 460 | fs/minix/namei.c | if (!empty_dir(inode)) { |
inode | 464 | fs/minix/namei.c | if (de->inode != inode->i_ino) { |
inode | 468 | fs/minix/namei.c | if (inode->i_count > 1) { |
inode | 472 | fs/minix/namei.c | if (inode->i_nlink != 2) |
inode | 473 | fs/minix/namei.c | printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); |
inode | 474 | fs/minix/namei.c | de->inode = 0; |
inode | 477 | fs/minix/namei.c | inode->i_nlink=0; |
inode | 478 | fs/minix/namei.c | inode->i_dirt=1; |
inode | 479 | fs/minix/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 485 | fs/minix/namei.c | iput(inode); |
inode | 490 | fs/minix/namei.c | int minix_unlink(struct inode * dir, const char * name, int len) |
inode | 493 | fs/minix/namei.c | struct inode * inode; |
inode | 499 | fs/minix/namei.c | inode = NULL; |
inode | 503 | fs/minix/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 506 | fs/minix/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 508 | fs/minix/namei.c | if (de->inode != inode->i_ino) { |
inode | 509 | fs/minix/namei.c | iput(inode); |
inode | 516 | fs/minix/namei.c | current->fsuid != inode->i_uid && |
inode | 519 | fs/minix/namei.c | if (de->inode != inode->i_ino) { |
inode | 523 | fs/minix/namei.c | if (!inode->i_nlink) { |
inode | 525 | fs/minix/namei.c | inode->i_dev,inode->i_ino,inode->i_nlink); |
inode | 526 | fs/minix/namei.c | inode->i_nlink=1; |
inode | 528 | fs/minix/namei.c | de->inode = 0; |
inode | 533 | fs/minix/namei.c | inode->i_nlink--; |
inode | 534 | fs/minix/namei.c | inode->i_ctime = dir->i_ctime; |
inode | 535 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 539 | fs/minix/namei.c | iput(inode); |
inode | 544 | fs/minix/namei.c | int minix_symlink(struct inode * dir, const char * name, int len, const char * symname) |
inode | 547 | fs/minix/namei.c | struct inode * inode = NULL; |
inode | 552 | fs/minix/namei.c | if (!(inode = minix_new_inode(dir))) { |
inode | 556 | fs/minix/namei.c | inode->i_mode = S_IFLNK | 0777; |
inode | 557 | fs/minix/namei.c | inode->i_op = &minix_symlink_inode_operations; |
inode | 558 | fs/minix/namei.c | name_block = minix_bread(inode,0,1); |
inode | 561 | fs/minix/namei.c | inode->i_nlink--; |
inode | 562 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 563 | fs/minix/namei.c | iput(inode); |
inode | 572 | fs/minix/namei.c | inode->i_size = i; |
inode | 573 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 576 | fs/minix/namei.c | inode->i_nlink--; |
inode | 577 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 578 | fs/minix/namei.c | iput(inode); |
inode | 585 | fs/minix/namei.c | inode->i_nlink--; |
inode | 586 | fs/minix/namei.c | inode->i_dirt = 1; |
inode | 587 | fs/minix/namei.c | iput(inode); |
inode | 591 | fs/minix/namei.c | de->inode = inode->i_ino; |
inode | 595 | fs/minix/namei.c | iput(inode); |
inode | 599 | fs/minix/namei.c | int minix_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
inode | 628 | fs/minix/namei.c | de->inode = oldinode->i_ino; |
inode | 639 | fs/minix/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 664 | fs/minix/namei.c | (((struct minix_dir_entry *) ((buffer)+info->s_dirsize))->inode) |
inode | 676 | fs/minix/namei.c | static int do_minix_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 677 | fs/minix/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 679 | fs/minix/namei.c | struct inode * old_inode, * new_inode; |
inode | 702 | fs/minix/namei.c | old_inode = __iget(old_dir->i_sb, old_de->inode,0); /* don't cross mnt-points */ |
inode | 712 | fs/minix/namei.c | new_inode = __iget(new_dir->i_sb, new_de->inode, 0); |
inode | 764 | fs/minix/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 766 | fs/minix/namei.c | if (new_de->inode && !new_inode) |
inode | 768 | fs/minix/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 771 | fs/minix/namei.c | old_de->inode = 0; |
inode | 772 | fs/minix/namei.c | new_de->inode = old_inode->i_ino; |
inode | 820 | fs/minix/namei.c | int minix_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 821 | fs/minix/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 21 | fs/minix/symlink.c | static int minix_readlink(struct inode *, char *, int); |
inode | 22 | fs/minix/symlink.c | static int minix_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 45 | fs/minix/symlink.c | static int minix_follow_link(struct inode * dir, struct inode * inode, |
inode | 46 | fs/minix/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 56 | fs/minix/symlink.c | if (!inode) { |
inode | 60 | fs/minix/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 62 | fs/minix/symlink.c | *res_inode = inode; |
inode | 66 | fs/minix/symlink.c | iput(inode); |
inode | 70 | fs/minix/symlink.c | if (!(bh = minix_bread(inode, 0, 0))) { |
inode | 71 | fs/minix/symlink.c | iput(inode); |
inode | 75 | fs/minix/symlink.c | iput(inode); |
inode | 83 | fs/minix/symlink.c | static int minix_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 89 | fs/minix/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 90 | fs/minix/symlink.c | iput(inode); |
inode | 95 | fs/minix/symlink.c | bh = minix_bread(inode, 0, 0); |
inode | 96 | fs/minix/symlink.c | iput(inode); |
inode | 30 | fs/minix/truncate.c | static int trunc_direct(struct inode * inode) |
inode | 36 | fs/minix/truncate.c | #define DIRECT_BLOCK ((inode->i_size + 1023) >> 10) |
inode | 40 | fs/minix/truncate.c | p = i + inode->u.minix_i.i_data; |
inode | 43 | fs/minix/truncate.c | bh = get_hash_table(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 54 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 56 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 61 | fs/minix/truncate.c | static int trunc_indirect(struct inode * inode, int offset, unsigned short * p) |
inode | 73 | fs/minix/truncate.c | ind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 92 | fs/minix/truncate.c | bh = get_hash_table(inode->i_dev,tmp,BLOCK_SIZE); |
inode | 105 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 117 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 123 | fs/minix/truncate.c | static int trunc_dindirect(struct inode * inode) |
inode | 131 | fs/minix/truncate.c | p = 8 + inode->u.minix_i.i_data; |
inode | 134 | fs/minix/truncate.c | dind_bh = bread(inode->i_dev, tmp, BLOCK_SIZE); |
inode | 150 | fs/minix/truncate.c | retry |= trunc_indirect(inode,7+512+(i<<9),dind); |
inode | 163 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 164 | fs/minix/truncate.c | minix_free_block(inode->i_sb,tmp); |
inode | 170 | fs/minix/truncate.c | void minix_truncate(struct inode * inode) |
inode | 174 | fs/minix/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 175 | fs/minix/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 178 | fs/minix/truncate.c | retry = trunc_direct(inode); |
inode | 179 | fs/minix/truncate.c | retry |= trunc_indirect(inode,7,inode->u.minix_i.i_data+7); |
inode | 180 | fs/minix/truncate.c | retry |= trunc_dindirect(inode); |
inode | 186 | fs/minix/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 187 | fs/minix/truncate.c | inode->i_dirt = 1; |
inode | 29 | fs/msdos/dir.c | static int msdos_dir_read(struct inode * inode,struct file * filp, char * buf,int count) |
inode | 66 | fs/msdos/dir.c | struct inode *inode, |
inode | 71 | fs/msdos/dir.c | struct super_block *sb = inode->i_sb; |
inode | 77 | fs/msdos/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) return -EBADF; |
inode | 78 | fs/msdos/dir.c | if (inode->i_ino == MSDOS_ROOT_INO) { |
inode | 93 | fs/msdos/dir.c | while ((ino = msdos_get_entry(inode,&filp->f_pos,&bh,&de)) > -1) { |
inode | 117 | fs/msdos/dir.c | ino = inode->i_ino; |
inode | 119 | fs/msdos/dir.c | ino = msdos_parent_ino(inode,0); |
inode | 123 | fs/msdos/fat.c | void cache_lookup(struct inode *inode,int cluster,int *f_clu,int *d_clu) |
inode | 128 | fs/msdos/fat.c | printk("cache lookup: <%d,%d> %d (%d,%d) -> ",inode->i_dev,inode->i_ino,cluster, |
inode | 132 | fs/msdos/fat.c | if (inode->i_dev == walk->device && walk->ino == inode->i_ino && |
inode | 163 | fs/msdos/fat.c | void cache_add(struct inode *inode,int f_clu,int d_clu) |
inode | 168 | fs/msdos/fat.c | printk("cache add: <%d,%d> %d (%d)\n",inode->i_dev,inode->i_ino,f_clu,d_clu); |
inode | 172 | fs/msdos/fat.c | if (inode->i_dev == walk->device && walk->ino == inode->i_ino && |
inode | 176 | fs/msdos/fat.c | cache_inval_inode(inode); |
inode | 189 | fs/msdos/fat.c | walk->device = inode->i_dev; |
inode | 190 | fs/msdos/fat.c | walk->ino = inode->i_ino; |
inode | 205 | fs/msdos/fat.c | void cache_inval_inode(struct inode *inode) |
inode | 210 | fs/msdos/fat.c | if (walk->device == inode->i_dev && walk->ino == inode->i_ino) |
inode | 224 | fs/msdos/fat.c | int get_cluster(struct inode *inode,int cluster) |
inode | 228 | fs/msdos/fat.c | if (!(nr = MSDOS_I(inode)->i_start)) return 0; |
inode | 231 | fs/msdos/fat.c | for (cache_lookup(inode,cluster,&count,&nr); count < cluster; |
inode | 233 | fs/msdos/fat.c | if ((nr = fat_access(inode->i_sb,nr,-1)) == -1) return 0; |
inode | 236 | fs/msdos/fat.c | cache_add(inode,cluster,nr); |
inode | 241 | fs/msdos/fat.c | int msdos_smap(struct inode *inode,int sector) |
inode | 246 | fs/msdos/fat.c | sb = MSDOS_SB(inode->i_sb); |
inode | 247 | fs/msdos/fat.c | if (inode->i_ino == MSDOS_ROOT_INO || (S_ISDIR(inode->i_mode) && |
inode | 248 | fs/msdos/fat.c | !MSDOS_I(inode)->i_start)) { |
inode | 254 | fs/msdos/fat.c | if (!(cluster = get_cluster(inode,cluster))) return 0; |
inode | 262 | fs/msdos/fat.c | int fat_free(struct inode *inode,int skip) |
inode | 266 | fs/msdos/fat.c | if (!(nr = MSDOS_I(inode)->i_start)) return 0; |
inode | 270 | fs/msdos/fat.c | if ((nr = fat_access(inode->i_sb,nr,-1)) == -1) return 0; |
inode | 277 | fs/msdos/fat.c | fat_access(inode->i_sb,last,MSDOS_SB(inode->i_sb)->fat_bits == |
inode | 280 | fs/msdos/fat.c | MSDOS_I(inode)->i_start = 0; |
inode | 281 | fs/msdos/fat.c | inode->i_dirt = 1; |
inode | 283 | fs/msdos/fat.c | lock_fat(inode->i_sb); |
inode | 285 | fs/msdos/fat.c | if (!(nr = fat_access(inode->i_sb,nr,0))) { |
inode | 286 | fs/msdos/fat.c | fs_panic(inode->i_sb,"fat_free: deleting beyond EOF"); |
inode | 289 | fs/msdos/fat.c | if (MSDOS_SB(inode->i_sb)->free_clusters != -1) |
inode | 290 | fs/msdos/fat.c | MSDOS_SB(inode->i_sb)->free_clusters++; |
inode | 291 | fs/msdos/fat.c | inode->i_blocks -= MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 293 | fs/msdos/fat.c | unlock_fat(inode->i_sb); |
inode | 294 | fs/msdos/fat.c | cache_inval_inode(inode); |
inode | 123 | fs/msdos/file.c | struct inode *inode, |
inode | 127 | fs/msdos/file.c | struct super_block *sb = inode->i_sb; |
inode | 133 | fs/msdos/file.c | int sector = msdos_smap(inode,pre->file_sector); |
inode | 138 | fs/msdos/file.c | bh = getblk(inode->i_dev,sector,SECTOR_SIZE); |
inode | 154 | fs/msdos/file.c | struct inode *inode, |
inode | 159 | fs/msdos/file.c | struct super_block *sb = inode->i_sb; |
inode | 167 | fs/msdos/file.c | if (!inode) { |
inode | 172 | fs/msdos/file.c | if (!S_ISREG(inode->i_mode) && !S_ISLNK(inode->i_mode)) { |
inode | 173 | fs/msdos/file.c | printk("msdos_file_read: mode = %07o\n",inode->i_mode); |
inode | 176 | fs/msdos/file.c | if (filp->f_pos >= inode->i_size || count <= 0) return 0; |
inode | 186 | fs/msdos/file.c | PRINTK (("#### ino %ld pos %ld size %ld count %d\n",inode->i_ino,filp->f_pos,inode->i_size,count)); |
inode | 197 | fs/msdos/file.c | if (filp->f_reada || !MSDOS_I(inode)->i_binary){ |
inode | 201 | fs/msdos/file.c | int ahead = read_ahead[MAJOR(inode->i_dev)]; |
inode | 208 | fs/msdos/file.c | msdos_prefetch (inode,&pre,to_reada); |
inode | 211 | fs/msdos/file.c | PRINTK (("count %d ahead %d nblist %d\n",count,read_ahead[MAJOR(inode->i_dev)],pre.nblist)); |
inode | 212 | fs/msdos/file.c | while ((left_in_file = inode->i_size - filp->f_pos) > 0 |
inode | 224 | fs/msdos/file.c | msdos_prefetch (inode,&pre,MSDOS_PREFETCH/2); |
inode | 237 | fs/msdos/file.c | if (MSDOS_I(inode)->i_binary) { |
inode | 247 | fs/msdos/file.c | filp->f_pos = inode->i_size; |
inode | 259 | fs/msdos/file.c | if (!IS_RDONLY(inode)) inode->i_atime = CURRENT_TIME; |
inode | 268 | fs/msdos/file.c | struct inode *inode, |
inode | 273 | fs/msdos/file.c | struct super_block *sb = inode->i_sb; |
inode | 278 | fs/msdos/file.c | int binary_mode = MSDOS_I(inode)->i_binary; |
inode | 280 | fs/msdos/file.c | if (!inode) { |
inode | 285 | fs/msdos/file.c | if (!S_ISREG(inode->i_mode) && !S_ISLNK(inode->i_mode)) { |
inode | 286 | fs/msdos/file.c | printk("msdos_file_write: mode = %07o\n",inode->i_mode); |
inode | 293 | fs/msdos/file.c | if (filp->f_flags & O_APPEND) filp->f_pos = inode->i_size; |
inode | 297 | fs/msdos/file.c | while (!(sector = msdos_smap(inode,filp->f_pos >> SECTOR_BITS))) |
inode | 298 | fs/msdos/file.c | if ((error = msdos_add_cluster(inode)) < 0) break; |
inode | 300 | fs/msdos/file.c | msdos_truncate(inode); |
inode | 308 | fs/msdos/file.c | || filp->f_pos + size >= inode->i_size)){ |
inode | 312 | fs/msdos/file.c | if (!(bh = getblk(inode->i_dev,sector,SECTOR_SIZE))){ |
inode | 316 | fs/msdos/file.c | }else if (!(bh = bread(inode->i_dev,sector,SECTOR_SIZE))) { |
inode | 346 | fs/msdos/file.c | if (filp->f_pos > inode->i_size) { |
inode | 347 | fs/msdos/file.c | inode->i_size = filp->f_pos; |
inode | 348 | fs/msdos/file.c | inode->i_dirt = 1; |
inode | 356 | fs/msdos/file.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 357 | fs/msdos/file.c | MSDOS_I(inode)->i_attrs |= ATTR_ARCH; |
inode | 358 | fs/msdos/file.c | inode->i_dirt = 1; |
inode | 362 | fs/msdos/file.c | void msdos_truncate(struct inode *inode) |
inode | 366 | fs/msdos/file.c | cluster = SECTOR_SIZE*MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 367 | fs/msdos/file.c | (void) fat_free(inode,(inode->i_size+(cluster-1))/cluster); |
inode | 368 | fs/msdos/file.c | MSDOS_I(inode)->i_attrs |= ATTR_ARCH; |
inode | 369 | fs/msdos/file.c | inode->i_dirt = 1; |
inode | 33 | fs/msdos/inode.c | void msdos_put_inode(struct inode *inode) |
inode | 35 | fs/msdos/inode.c | struct inode *depend; |
inode | 38 | fs/msdos/inode.c | if (inode->i_nlink) { |
inode | 39 | fs/msdos/inode.c | if (MSDOS_I(inode)->i_busy) cache_inval_inode(inode); |
inode | 42 | fs/msdos/inode.c | inode->i_size = 0; |
inode | 43 | fs/msdos/inode.c | msdos_truncate(inode); |
inode | 44 | fs/msdos/inode.c | depend = MSDOS_I(inode)->i_depend; |
inode | 45 | fs/msdos/inode.c | sb = inode->i_sb; |
inode | 46 | fs/msdos/inode.c | clear_inode(inode); |
inode | 48 | fs/msdos/inode.c | if (MSDOS_I(depend)->i_old != inode) { |
inode | 50 | fs/msdos/inode.c | depend, inode, MSDOS_I(depend)->i_old); |
inode | 337 | fs/msdos/inode.c | int msdos_bmap(struct inode *inode,int block) |
inode | 342 | fs/msdos/inode.c | sb = MSDOS_SB(inode->i_sb); |
inode | 343 | fs/msdos/inode.c | if (inode->i_ino == MSDOS_ROOT_INO) { |
inode | 348 | fs/msdos/inode.c | if (!(cluster = get_cluster(inode,cluster))) return 0; |
inode | 353 | fs/msdos/inode.c | void msdos_read_inode(struct inode *inode) |
inode | 355 | fs/msdos/inode.c | struct super_block *sb = inode->i_sb; |
inode | 361 | fs/msdos/inode.c | MSDOS_I(inode)->i_busy = 0; |
inode | 362 | fs/msdos/inode.c | MSDOS_I(inode)->i_depend = MSDOS_I(inode)->i_old = NULL; |
inode | 363 | fs/msdos/inode.c | MSDOS_I(inode)->i_binary = 1; |
inode | 364 | fs/msdos/inode.c | inode->i_uid = MSDOS_SB(inode->i_sb)->fs_uid; |
inode | 365 | fs/msdos/inode.c | inode->i_gid = MSDOS_SB(inode->i_sb)->fs_gid; |
inode | 366 | fs/msdos/inode.c | if (inode->i_ino == MSDOS_ROOT_INO) { |
inode | 367 | fs/msdos/inode.c | inode->i_mode = (S_IRWXUGO & ~MSDOS_SB(inode->i_sb)->fs_umask) | |
inode | 369 | fs/msdos/inode.c | inode->i_op = &msdos_dir_inode_operations; |
inode | 370 | fs/msdos/inode.c | inode->i_nlink = msdos_subdirs(inode)+2; |
inode | 372 | fs/msdos/inode.c | inode->i_size = MSDOS_SB(inode->i_sb)->dir_entries* |
inode | 374 | fs/msdos/inode.c | inode->i_blksize = MSDOS_SB(inode->i_sb)->cluster_size* |
inode | 376 | fs/msdos/inode.c | inode->i_blocks = (inode->i_size+inode->i_blksize-1)/ |
inode | 377 | fs/msdos/inode.c | inode->i_blksize*MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 378 | fs/msdos/inode.c | MSDOS_I(inode)->i_start = 0; |
inode | 379 | fs/msdos/inode.c | MSDOS_I(inode)->i_attrs = 0; |
inode | 380 | fs/msdos/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = 0; |
inode | 383 | fs/msdos/inode.c | if (!(bh = bread(inode->i_dev,inode->i_ino >> MSDOS_DPB_BITS, |
inode | 385 | fs/msdos/inode.c | printk("dev = 0x%04X, ino = %ld\n",inode->i_dev,inode->i_ino); |
inode | 389 | fs/msdos/inode.c | [inode->i_ino & (MSDOS_DPB-1)]; |
inode | 391 | fs/msdos/inode.c | inode->i_mode = MSDOS_MKMODE(raw_entry->attr,S_IRWXUGO & |
inode | 392 | fs/msdos/inode.c | ~MSDOS_SB(inode->i_sb)->fs_umask) | S_IFDIR; |
inode | 393 | fs/msdos/inode.c | inode->i_op = &msdos_dir_inode_operations; |
inode | 394 | fs/msdos/inode.c | MSDOS_I(inode)->i_start = CF_LE_W(raw_entry->start); |
inode | 395 | fs/msdos/inode.c | inode->i_nlink = msdos_subdirs(inode); |
inode | 398 | fs/msdos/inode.c | if (!inode->i_nlink) { |
inode | 399 | fs/msdos/inode.c | printk("directory %d: i_nlink == 0\n",inode->i_ino); |
inode | 400 | fs/msdos/inode.c | inode->i_nlink = 1; |
inode | 403 | fs/msdos/inode.c | inode->i_size = 0; |
inode | 406 | fs/msdos/inode.c | inode->i_size += SECTOR_SIZE*MSDOS_SB(inode-> |
inode | 408 | fs/msdos/inode.c | if (!(nr = fat_access(inode->i_sb,nr,-1))) { |
inode | 410 | fs/msdos/inode.c | inode->i_ino); |
inode | 416 | fs/msdos/inode.c | inode->i_mode = MSDOS_MKMODE(raw_entry->attr,(IS_NOEXEC(inode) |
inode | 417 | fs/msdos/inode.c | ? S_IRUGO|S_IWUGO : S_IRWXUGO) & ~MSDOS_SB(inode->i_sb)->fs_umask) | |
inode | 419 | fs/msdos/inode.c | inode->i_op = sb->s_blocksize == 1024 |
inode | 422 | fs/msdos/inode.c | MSDOS_I(inode)->i_start = CF_LE_W(raw_entry->start); |
inode | 423 | fs/msdos/inode.c | inode->i_nlink = 1; |
inode | 424 | fs/msdos/inode.c | inode->i_size = CF_LE_L(raw_entry->size); |
inode | 426 | fs/msdos/inode.c | MSDOS_I(inode)->i_binary = is_binary(MSDOS_SB(inode->i_sb)->conversion, |
inode | 428 | fs/msdos/inode.c | MSDOS_I(inode)->i_attrs = raw_entry->attr & ATTR_UNUSED; |
inode | 430 | fs/msdos/inode.c | inode->i_blksize = MSDOS_SB(inode->i_sb)->cluster_size*SECTOR_SIZE; |
inode | 431 | fs/msdos/inode.c | inode->i_blocks = (inode->i_size+inode->i_blksize-1)/ |
inode | 432 | fs/msdos/inode.c | inode->i_blksize*MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 433 | fs/msdos/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = |
inode | 439 | fs/msdos/inode.c | void msdos_write_inode(struct inode *inode) |
inode | 441 | fs/msdos/inode.c | struct super_block *sb = inode->i_sb; |
inode | 445 | fs/msdos/inode.c | inode->i_dirt = 0; |
inode | 446 | fs/msdos/inode.c | if (inode->i_ino == MSDOS_ROOT_INO || !inode->i_nlink) return; |
inode | 447 | fs/msdos/inode.c | if (!(bh = bread(inode->i_dev,inode->i_ino >> MSDOS_DPB_BITS, |
inode | 449 | fs/msdos/inode.c | printk("dev = 0x%04X, ino = %ld\n",inode->i_dev,inode->i_ino); |
inode | 453 | fs/msdos/inode.c | [inode->i_ino & (MSDOS_DPB-1)]; |
inode | 454 | fs/msdos/inode.c | if (S_ISDIR(inode->i_mode)) { |
inode | 460 | fs/msdos/inode.c | raw_entry->size = CT_LE_L(inode->i_size); |
inode | 462 | fs/msdos/inode.c | raw_entry->attr |= MSDOS_MKATTR(inode->i_mode) | |
inode | 463 | fs/msdos/inode.c | MSDOS_I(inode)->i_attrs; |
inode | 464 | fs/msdos/inode.c | raw_entry->start = CT_LE_L(MSDOS_I(inode)->i_start); |
inode | 465 | fs/msdos/inode.c | date_unix2dos(inode->i_mtime,&raw_entry->time,&raw_entry->date); |
inode | 473 | fs/msdos/inode.c | int msdos_notify_change(struct inode * inode,struct iattr * attr) |
inode | 477 | fs/msdos/inode.c | error = inode_change_ok(inode, attr); |
inode | 482 | fs/msdos/inode.c | (attr->ia_uid != MSDOS_SB(inode->i_sb)->fs_uid)) || |
inode | 484 | fs/msdos/inode.c | (attr->ia_gid != MSDOS_SB(inode->i_sb)->fs_gid)) || |
inode | 490 | fs/msdos/inode.c | return MSDOS_SB(inode->i_sb)->quiet ? 0 : error; |
inode | 492 | fs/msdos/inode.c | inode_setattr(inode, attr); |
inode | 494 | fs/msdos/inode.c | if (IS_NOEXEC(inode) && !S_ISDIR(inode->i_mode)) |
inode | 495 | fs/msdos/inode.c | inode->i_mode &= S_IFMT | S_IRUGO | S_IWUGO; |
inode | 497 | fs/msdos/inode.c | inode->i_mode |= S_IXUGO; |
inode | 499 | fs/msdos/inode.c | inode->i_mode = ((inode->i_mode & S_IFMT) | ((((inode->i_mode & S_IRWXU |
inode | 500 | fs/msdos/inode.c | & ~MSDOS_SB(inode->i_sb)->fs_umask) | S_IRUSR) >> 6)*S_IXUGO)) & |
inode | 501 | fs/msdos/inode.c | ~MSDOS_SB(inode->i_sb)->fs_umask; |
inode | 117 | fs/msdos/misc.c | int msdos_add_cluster(struct inode *inode) |
inode | 119 | fs/msdos/misc.c | struct super_block *sb = inode->i_sb; |
inode | 122 | fs/msdos/misc.c | int cluster_size = MSDOS_SB(inode->i_sb)->cluster_size; |
inode | 124 | fs/msdos/misc.c | if (inode->i_ino == MSDOS_ROOT_INO) return -ENOSPC; |
inode | 125 | fs/msdos/misc.c | if (!MSDOS_SB(inode->i_sb)->free_clusters) return -ENOSPC; |
inode | 126 | fs/msdos/misc.c | lock_fat(inode->i_sb); |
inode | 127 | fs/msdos/misc.c | limit = MSDOS_SB(inode->i_sb)->clusters; |
inode | 130 | fs/msdos/misc.c | nr = ((count+MSDOS_SB(inode->i_sb)->prev_free) % limit)+2; |
inode | 131 | fs/msdos/misc.c | if (fat_access(inode->i_sb,nr,-1) == 0) break; |
inode | 136 | fs/msdos/misc.c | MSDOS_SB(inode->i_sb)->prev_free = (count+MSDOS_SB(inode->i_sb)-> |
inode | 139 | fs/msdos/misc.c | MSDOS_SB(inode->i_sb)->free_clusters = 0; |
inode | 140 | fs/msdos/misc.c | unlock_fat(inode->i_sb); |
inode | 143 | fs/msdos/misc.c | fat_access(inode->i_sb,nr,MSDOS_SB(inode->i_sb)->fat_bits == 12 ? |
inode | 145 | fs/msdos/misc.c | if (MSDOS_SB(inode->i_sb)->free_clusters != -1) |
inode | 146 | fs/msdos/misc.c | MSDOS_SB(inode->i_sb)->free_clusters--; |
inode | 147 | fs/msdos/misc.c | unlock_fat(inode->i_sb); |
inode | 149 | fs/msdos/misc.c | printk("set to %x\n",fat_access(inode->i_sb,nr,-1)); |
inode | 152 | fs/msdos/misc.c | if ((current = MSDOS_I(inode)->i_start) != 0) { |
inode | 153 | fs/msdos/misc.c | cache_lookup(inode,INT_MAX,&last,¤t); |
inode | 155 | fs/msdos/misc.c | if (!(current = fat_access(inode->i_sb, |
inode | 157 | fs/msdos/misc.c | fs_panic(inode->i_sb,"File without EOF"); |
inode | 164 | fs/msdos/misc.c | if (last) fat_access(inode->i_sb,last,nr); |
inode | 166 | fs/msdos/misc.c | MSDOS_I(inode)->i_start = nr; |
inode | 167 | fs/msdos/misc.c | inode->i_dirt = 1; |
inode | 170 | fs/msdos/misc.c | if (last) printk("next set to %d\n",fat_access(inode->i_sb,last,-1)); |
inode | 172 | fs/msdos/misc.c | sector = MSDOS_SB(inode->i_sb)->data_start+(nr-2)*cluster_size; |
inode | 178 | fs/msdos/misc.c | if (!(bh = getblk(inode->i_dev,sector,SECTOR_SIZE))) |
inode | 187 | fs/msdos/misc.c | inode->i_blocks += cluster_size; |
inode | 188 | fs/msdos/misc.c | if (S_ISDIR(inode->i_mode)) { |
inode | 189 | fs/msdos/misc.c | if (inode->i_size & (SECTOR_SIZE-1)) { |
inode | 190 | fs/msdos/misc.c | fs_panic(inode->i_sb,"Odd directory size"); |
inode | 191 | fs/msdos/misc.c | inode->i_size = (inode->i_size+SECTOR_SIZE) & |
inode | 194 | fs/msdos/misc.c | inode->i_size += SECTOR_SIZE*cluster_size; |
inode | 196 | fs/msdos/misc.c | printk("size is %d now (%x)\n",inode->i_size,inode); |
inode | 198 | fs/msdos/misc.c | inode->i_dirt = 1; |
inode | 261 | fs/msdos/misc.c | int msdos_get_entry(struct inode *dir, loff_t *pos,struct buffer_head **bh, |
inode | 328 | fs/msdos/misc.c | inode = iget(sb,sector*MSDOS_DPS+entry); \ |
inode | 329 | fs/msdos/misc.c | if (inode) { \ |
inode | 331 | fs/msdos/misc.c | done = !MSDOS_I(inode)->i_busy; \ |
inode | 332 | fs/msdos/misc.c | iput(inode); \ |
inode | 350 | fs/msdos/misc.c | struct inode *inode; |
inode | 454 | fs/msdos/misc.c | int msdos_parent_ino(struct inode *dir,int locked) |
inode | 490 | fs/msdos/misc.c | int msdos_subdirs(struct inode *dir) |
inode | 511 | fs/msdos/misc.c | int msdos_scan(struct inode *dir,char *name,struct buffer_head **res_bh, |
inode | 35 | fs/msdos/mmap.c | struct inode * inode = area->vm_inode; |
inode | 44 | fs/msdos/mmap.c | gap = inode->i_size - pos; |
inode | 61 | fs/msdos/mmap.c | cur_read = msdos_file_read (inode,&filp,(char*)page |
inode | 93 | fs/msdos/mmap.c | int msdos_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 97 | fs/msdos/mmap.c | if (vma->vm_offset & (inode->i_sb->s_blocksize - 1)) |
inode | 99 | fs/msdos/mmap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 101 | fs/msdos/mmap.c | if (!IS_RDONLY(inode)) { |
inode | 102 | fs/msdos/mmap.c | inode->i_atime = CURRENT_TIME; |
inode | 103 | fs/msdos/mmap.c | inode->i_dirt = 1; |
inode | 106 | fs/msdos/mmap.c | vma->vm_inode = inode; |
inode | 107 | fs/msdos/mmap.c | inode->i_count++; |
inode | 101 | fs/msdos/namei.c | static int msdos_find(struct inode *dir,const char *name,int len, |
inode | 113 | fs/msdos/namei.c | int msdos_lookup(struct inode *dir,const char *name,int len, |
inode | 114 | fs/msdos/namei.c | struct inode **result) |
inode | 120 | fs/msdos/namei.c | struct inode *next; |
inode | 180 | fs/msdos/namei.c | static int msdos_create_entry(struct inode *dir,char *name,int is_dir, |
inode | 181 | fs/msdos/namei.c | struct inode **result) |
inode | 217 | fs/msdos/namei.c | int msdos_create(struct inode *dir,const char *name,int len,int mode, |
inode | 218 | fs/msdos/namei.c | struct inode **result) |
inode | 266 | fs/msdos/namei.c | int msdos_mkdir(struct inode *dir,const char *name,int len,int mode) |
inode | 271 | fs/msdos/namei.c | struct inode *inode,*dot; |
inode | 287 | fs/msdos/namei.c | if ((res = msdos_create_entry(dir,msdos_name,1,&inode)) < 0) { |
inode | 293 | fs/msdos/namei.c | inode->i_nlink = 2; /* no need to mark them dirty */ |
inode | 294 | fs/msdos/namei.c | MSDOS_I(inode)->i_busy = 1; /* prevent lookups */ |
inode | 295 | fs/msdos/namei.c | if ((res = msdos_add_cluster(inode)) < 0) goto mkdir_error; |
inode | 296 | fs/msdos/namei.c | if ((res = msdos_create_entry(inode,MSDOS_DOT,1,&dot)) < 0) |
inode | 298 | fs/msdos/namei.c | dot->i_size = inode->i_size; /* doesn't grow in the 2nd create_entry */ |
inode | 299 | fs/msdos/namei.c | MSDOS_I(dot)->i_start = MSDOS_I(inode)->i_start; |
inode | 300 | fs/msdos/namei.c | dot->i_nlink = inode->i_nlink; |
inode | 303 | fs/msdos/namei.c | if ((res = msdos_create_entry(inode,MSDOS_DOTDOT,1,&dot)) < 0) |
inode | 310 | fs/msdos/namei.c | MSDOS_I(inode)->i_busy = 0; |
inode | 312 | fs/msdos/namei.c | iput(inode); |
inode | 316 | fs/msdos/namei.c | iput(inode); |
inode | 324 | fs/msdos/namei.c | static int msdos_empty(struct inode *dir) |
inode | 350 | fs/msdos/namei.c | int msdos_rmdir(struct inode *dir,const char *name,int len) |
inode | 356 | fs/msdos/namei.c | struct inode *inode; |
inode | 359 | fs/msdos/namei.c | inode = NULL; |
inode | 365 | fs/msdos/namei.c | if (!(inode = iget(dir->i_sb,ino))) goto rmdir_done; |
inode | 367 | fs/msdos/namei.c | if (!S_ISDIR(inode->i_mode)) goto rmdir_done; |
inode | 369 | fs/msdos/namei.c | if (dir->i_dev != inode->i_dev || dir == inode) goto rmdir_done; |
inode | 370 | fs/msdos/namei.c | res = msdos_empty(inode); |
inode | 373 | fs/msdos/namei.c | inode->i_nlink = 0; |
inode | 374 | fs/msdos/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 376 | fs/msdos/namei.c | inode->i_dirt = dir->i_dirt = 1; |
inode | 383 | fs/msdos/namei.c | iput(inode); |
inode | 389 | fs/msdos/namei.c | struct inode *dir, |
inode | 398 | fs/msdos/namei.c | struct inode *inode; |
inode | 401 | fs/msdos/namei.c | inode = NULL; |
inode | 404 | fs/msdos/namei.c | if (!(inode = iget(dir->i_sb,ino))) { |
inode | 408 | fs/msdos/namei.c | if (!S_ISREG(inode->i_mode) && nospc){ |
inode | 412 | fs/msdos/namei.c | inode->i_nlink = 0; |
inode | 413 | fs/msdos/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 414 | fs/msdos/namei.c | MSDOS_I(inode)->i_busy = 1; |
inode | 415 | fs/msdos/namei.c | inode->i_dirt = dir->i_dirt = 1; |
inode | 420 | fs/msdos/namei.c | iput(inode); |
inode | 425 | fs/msdos/namei.c | int msdos_unlink(struct inode *dir,const char *name,int len) |
inode | 432 | fs/msdos/namei.c | int msdos_unlink_umsdos(struct inode *dir,const char *name,int len) |
inode | 437 | fs/msdos/namei.c | static int rename_same_dir(struct inode *old_dir,char *old_name, |
inode | 438 | fs/msdos/namei.c | struct inode *new_dir,char *new_name,struct buffer_head *old_bh, |
inode | 444 | fs/msdos/namei.c | struct inode *new_inode,*old_inode; |
inode | 489 | fs/msdos/namei.c | static int rename_diff_dir(struct inode *old_dir,char *old_name, |
inode | 490 | fs/msdos/namei.c | struct inode *new_dir,char *new_name,struct buffer_head *old_bh, |
inode | 496 | fs/msdos/namei.c | struct inode *old_inode,*new_inode,*free_inode,*dotdot_inode,*walk; |
inode | 609 | fs/msdos/namei.c | int msdos_rename(struct inode *old_dir,const char *old_name,int old_len, |
inode | 610 | fs/msdos/namei.c | struct inode *new_dir,const char *new_name,int new_len) |
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_wcount++; |
inode | 143 | fs/namei.c | void put_write_access(struct inode * inode) |
inode | 145 | fs/namei.c | inode->i_wcount--; |
inode | 153 | fs/namei.c | int lookup(struct inode * dir,const char * name, int len, |
inode | 154 | fs/namei.c | struct inode ** result) |
inode | 192 | fs/namei.c | int follow_link(struct inode * dir, struct inode * inode, |
inode | 193 | fs/namei.c | int flag, int mode, struct inode ** res_inode) |
inode | 195 | fs/namei.c | if (!dir || !inode) { |
inode | 197 | fs/namei.c | iput(inode); |
inode | 201 | fs/namei.c | if (!inode->i_op || !inode->i_op->follow_link) { |
inode | 203 | fs/namei.c | *res_inode = inode; |
inode | 206 | fs/namei.c | return inode->i_op->follow_link(dir,inode,flag,mode,res_inode); |
inode | 216 | fs/namei.c | struct inode * base, struct inode ** res_inode) |
inode | 221 | fs/namei.c | struct inode * inode; |
inode | 241 | fs/namei.c | error = lookup(base,thisname,len,&inode); |
inode | 246 | fs/namei.c | error = follow_link(base,inode,0,0,&base); |
inode | 260 | fs/namei.c | static int _namei(const char * pathname, struct inode * base, |
inode | 261 | fs/namei.c | int follow_links, struct inode ** res_inode) |
inode | 265 | fs/namei.c | struct inode * inode; |
inode | 272 | fs/namei.c | error = lookup(base,basename,namelen,&inode); |
inode | 278 | fs/namei.c | error = follow_link(base,inode,0,0,&inode); |
inode | 283 | fs/namei.c | *res_inode = inode; |
inode | 287 | fs/namei.c | int lnamei(const char * pathname, struct inode ** res_inode) |
inode | 307 | fs/namei.c | int namei(const char * pathname, struct inode ** res_inode) |
inode | 334 | fs/namei.c | struct inode ** res_inode, struct inode * base) |
inode | 338 | fs/namei.c | struct inode * dir, *inode; |
inode | 361 | fs/namei.c | error = lookup(dir,basename,namelen,&inode); |
inode | 364 | fs/namei.c | iput(inode); |
inode | 382 | fs/namei.c | error = lookup(dir,basename,namelen,&inode); |
inode | 387 | fs/namei.c | error = follow_link(dir,inode,flag,mode,&inode); |
inode | 390 | fs/namei.c | if (S_ISDIR(inode->i_mode) && (flag & 2)) { |
inode | 391 | fs/namei.c | iput(inode); |
inode | 394 | fs/namei.c | if ((error = permission(inode,ACC_MODE(flag))) != 0) { |
inode | 395 | fs/namei.c | iput(inode); |
inode | 398 | fs/namei.c | if (S_ISBLK(inode->i_mode) || S_ISCHR(inode->i_mode)) { |
inode | 399 | fs/namei.c | if (IS_NODEV(inode)) { |
inode | 400 | fs/namei.c | iput(inode); |
inode | 405 | fs/namei.c | if (IS_RDONLY(inode) && (flag & 2)) { |
inode | 406 | fs/namei.c | iput(inode); |
inode | 413 | fs/namei.c | if (IS_APPEND(inode) && ((flag & 2) && !(flag & O_APPEND))) { |
inode | 414 | fs/namei.c | iput(inode); |
inode | 420 | fs/namei.c | if ((error = get_write_access(inode))) { |
inode | 421 | fs/namei.c | iput(inode); |
inode | 426 | fs/namei.c | if ((error = notify_change(inode, &newattrs))) { |
inode | 427 | fs/namei.c | put_write_access(inode); |
inode | 428 | fs/namei.c | iput(inode); |
inode | 431 | fs/namei.c | inode->i_size = 0; |
inode | 432 | fs/namei.c | if (inode->i_op && inode->i_op->truncate) |
inode | 433 | fs/namei.c | inode->i_op->truncate(inode); |
inode | 434 | fs/namei.c | inode->i_dirt = 1; |
inode | 435 | fs/namei.c | put_write_access(inode); |
inode | 437 | fs/namei.c | *res_inode = inode; |
inode | 445 | fs/namei.c | struct inode * dir; |
inode | 503 | fs/namei.c | struct inode * dir; |
inode | 549 | fs/namei.c | struct inode * dir; |
inode | 597 | fs/namei.c | struct inode * dir; |
inode | 643 | fs/namei.c | struct inode * dir; |
inode | 691 | fs/namei.c | static int do_link(struct inode * oldinode, const char * newname) |
inode | 693 | fs/namei.c | struct inode * dir; |
inode | 747 | fs/namei.c | struct inode * oldinode; |
inode | 764 | fs/namei.c | struct inode * old_dir, * new_dir; |
inode | 28 | fs/nfs/dir.c | static int nfs_dir_read(struct inode *, struct file *filp, char *buf, |
inode | 30 | fs/nfs/dir.c | static int nfs_readdir(struct inode *, struct file *, struct dirent *, int); |
inode | 31 | fs/nfs/dir.c | static int nfs_lookup(struct inode *dir, const char *name, int len, |
inode | 32 | fs/nfs/dir.c | struct inode **result); |
inode | 33 | fs/nfs/dir.c | static int nfs_create(struct inode *dir, const char *name, int len, int mode, |
inode | 34 | fs/nfs/dir.c | struct inode **result); |
inode | 35 | fs/nfs/dir.c | static int nfs_mkdir(struct inode *dir, const char *name, int len, int mode); |
inode | 36 | fs/nfs/dir.c | static int nfs_rmdir(struct inode *dir, const char *name, int len); |
inode | 37 | fs/nfs/dir.c | static int nfs_unlink(struct inode *dir, const char *name, int len); |
inode | 38 | fs/nfs/dir.c | static int nfs_symlink(struct inode *inode, const char *name, int len, |
inode | 40 | fs/nfs/dir.c | static int nfs_link(struct inode *oldinode, struct inode *dir, |
inode | 42 | fs/nfs/dir.c | static int nfs_mknod(struct inode *dir, const char *name, int len, int mode, |
inode | 44 | fs/nfs/dir.c | static int nfs_rename(struct inode *old_dir, const char *old_name, |
inode | 45 | fs/nfs/dir.c | int old_len, struct inode *new_dir, const char *new_name, |
inode | 79 | fs/nfs/dir.c | static int nfs_dir_read(struct inode *inode, struct file *filp, char *buf, |
inode | 93 | fs/nfs/dir.c | static int nfs_readdir(struct inode *inode, struct file *filp, |
inode | 105 | fs/nfs/dir.c | if (!inode || !S_ISDIR(inode->i_mode)) { |
inode | 124 | fs/nfs/dir.c | if (inode->i_dev == c_dev && inode->i_ino == c_ino) { |
inode | 141 | fs/nfs/dir.c | result = nfs_proc_readdir(NFS_SERVER(inode), NFS_FH(inode), |
inode | 148 | fs/nfs/dir.c | c_dev = inode->i_dev; |
inode | 149 | fs/nfs/dir.c | c_ino = inode->i_ino; |
inode | 183 | fs/nfs/dir.c | int inode; |
inode | 190 | fs/nfs/dir.c | static struct nfs_lookup_cache_entry *nfs_lookup_cache_index(struct inode *dir, |
inode | 198 | fs/nfs/dir.c | if (entry->dev == dir->i_dev && entry->inode == dir->i_ino |
inode | 205 | fs/nfs/dir.c | static int nfs_lookup_cache_lookup(struct inode *dir, const char *filename, |
inode | 229 | fs/nfs/dir.c | static void nfs_lookup_cache_add(struct inode *dir, const char *filename, |
inode | 246 | fs/nfs/dir.c | entry->inode = dir->i_ino; |
inode | 254 | fs/nfs/dir.c | static void nfs_lookup_cache_remove(struct inode *dir, struct inode *inode, |
inode | 262 | fs/nfs/dir.c | if (inode) { |
inode | 263 | fs/nfs/dir.c | dev = inode->i_dev; |
inode | 264 | fs/nfs/dir.c | fileid = inode->i_ino; |
inode | 279 | fs/nfs/dir.c | static void nfs_lookup_cache_refresh(struct inode *file, |
inode | 294 | fs/nfs/dir.c | static int nfs_lookup(struct inode *dir, const char *__name, int len, |
inode | 295 | fs/nfs/dir.c | struct inode **result) |
inode | 335 | fs/nfs/dir.c | static int nfs_create(struct inode *dir, const char *name, int len, int mode, |
inode | 336 | fs/nfs/dir.c | struct inode **result) |
inode | 370 | fs/nfs/dir.c | static int nfs_mknod(struct inode *dir, const char *name, int len, |
inode | 402 | fs/nfs/dir.c | static int nfs_mkdir(struct inode *dir, const char *name, int len, int mode) |
inode | 429 | fs/nfs/dir.c | static int nfs_rmdir(struct inode *dir, const char *name, int len) |
inode | 449 | fs/nfs/dir.c | static int nfs_unlink(struct inode *dir, const char *name, int len) |
inode | 469 | fs/nfs/dir.c | static int nfs_symlink(struct inode *dir, const char *name, int len, |
inode | 497 | fs/nfs/dir.c | static int nfs_link(struct inode *oldinode, struct inode *dir, |
inode | 528 | fs/nfs/dir.c | static int nfs_rename(struct inode *old_dir, const char *old_name, int old_len, |
inode | 529 | fs/nfs/dir.c | struct inode *new_dir, const char *new_name, int new_len) |
inode | 568 | fs/nfs/dir.c | void nfs_refresh_inode(struct inode *inode, struct nfs_fattr *fattr) |
inode | 572 | fs/nfs/dir.c | if (!inode || !fattr) { |
inode | 576 | fs/nfs/dir.c | if (inode->i_ino != fattr->fileid) { |
inode | 580 | fs/nfs/dir.c | was_empty = inode->i_mode == 0; |
inode | 581 | fs/nfs/dir.c | inode->i_mode = fattr->mode; |
inode | 582 | fs/nfs/dir.c | inode->i_nlink = fattr->nlink; |
inode | 583 | fs/nfs/dir.c | inode->i_uid = fattr->uid; |
inode | 584 | fs/nfs/dir.c | inode->i_gid = fattr->gid; |
inode | 585 | fs/nfs/dir.c | inode->i_size = fattr->size; |
inode | 586 | fs/nfs/dir.c | inode->i_blksize = fattr->blocksize; |
inode | 587 | fs/nfs/dir.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 588 | fs/nfs/dir.c | inode->i_rdev = fattr->rdev; |
inode | 590 | fs/nfs/dir.c | inode->i_rdev = 0; |
inode | 591 | fs/nfs/dir.c | inode->i_blocks = fattr->blocks; |
inode | 592 | fs/nfs/dir.c | inode->i_atime = fattr->atime.seconds; |
inode | 593 | fs/nfs/dir.c | inode->i_mtime = fattr->mtime.seconds; |
inode | 594 | fs/nfs/dir.c | inode->i_ctime = fattr->ctime.seconds; |
inode | 596 | fs/nfs/dir.c | if (S_ISREG(inode->i_mode)) |
inode | 597 | fs/nfs/dir.c | inode->i_op = &nfs_file_inode_operations; |
inode | 598 | fs/nfs/dir.c | else if (S_ISDIR(inode->i_mode)) |
inode | 599 | fs/nfs/dir.c | inode->i_op = &nfs_dir_inode_operations; |
inode | 600 | fs/nfs/dir.c | else if (S_ISLNK(inode->i_mode)) |
inode | 601 | fs/nfs/dir.c | inode->i_op = &nfs_symlink_inode_operations; |
inode | 602 | fs/nfs/dir.c | else if (S_ISCHR(inode->i_mode)) |
inode | 603 | fs/nfs/dir.c | inode->i_op = &chrdev_inode_operations; |
inode | 604 | fs/nfs/dir.c | else if (S_ISBLK(inode->i_mode)) |
inode | 605 | fs/nfs/dir.c | inode->i_op = &blkdev_inode_operations; |
inode | 606 | fs/nfs/dir.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 607 | fs/nfs/dir.c | init_fifo(inode); |
inode | 609 | fs/nfs/dir.c | inode->i_op = NULL; |
inode | 611 | fs/nfs/dir.c | nfs_lookup_cache_refresh(inode, fattr); |
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 *, char *, int); |
inode | 35 | fs/nfs/file.c | static int nfs_fsync(struct inode *, struct file *); |
inode | 93 | fs/nfs/file.c | static int nfs_fsync(struct inode *inode, struct file *file) |
inode | 98 | fs/nfs/file.c | static int nfs_file_read(struct inode *inode, struct file *file, char *buf, |
inode | 106 | fs/nfs/file.c | if (!inode) { |
inode | 110 | fs/nfs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 112 | fs/nfs/file.c | inode->i_mode); |
inode | 116 | fs/nfs/file.c | if (pos + count > inode->i_size) |
inode | 117 | fs/nfs/file.c | count = inode->i_size - pos; |
inode | 123 | fs/nfs/file.c | if ((cache[i].inode_num == inode->i_ino) |
inode | 138 | fs/nfs/file.c | n = NFS_SERVER(inode)->rsize; |
inode | 140 | fs/nfs/file.c | result = nfs_proc_read(NFS_SERVER(inode), NFS_FH(inode), |
inode | 148 | fs/nfs/file.c | nfs_refresh_inode(inode, &fattr); |
inode | 157 | fs/nfs/file.c | result = nfs_proc_read(NFS_SERVER(inode), NFS_FH(inode), |
inode | 169 | fs/nfs/file.c | nfs_refresh_inode(inode, &fattr); |
inode | 174 | fs/nfs/file.c | nfs_refresh_inode(inode, &fattr); |
inode | 181 | fs/nfs/file.c | cache[tail].inode_num = inode->i_ino; |
inode | 193 | fs/nfs/file.c | static int nfs_file_write(struct inode *inode, struct file *file, char *buf, |
inode | 199 | fs/nfs/file.c | if (!inode) { |
inode | 203 | fs/nfs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 205 | fs/nfs/file.c | inode->i_mode); |
inode | 214 | fs/nfs/file.c | if(cache[i].inode_num == inode->i_ino) |
inode | 220 | fs/nfs/file.c | pos = inode->i_size; |
inode | 221 | fs/nfs/file.c | n = NFS_SERVER(inode)->wsize; |
inode | 226 | fs/nfs/file.c | result = nfs_proc_write(NFS_SERVER(inode), NFS_FH(inode), |
inode | 238 | fs/nfs/file.c | nfs_refresh_inode(inode, &fattr); |
inode | 34 | fs/nfs/inode.c | static int nfs_notify_change(struct inode *, struct iattr *); |
inode | 35 | fs/nfs/inode.c | static void nfs_put_inode(struct inode *); |
inode | 50 | fs/nfs/inode.c | static void nfs_put_inode(struct inode * inode) |
inode | 52 | fs/nfs/inode.c | clear_inode(inode); |
inode | 177 | fs/nfs/inode.c | struct inode *nfs_fhget(struct super_block *sb, struct nfs_fh *fhandle, |
inode | 182 | fs/nfs/inode.c | struct inode *inode; |
inode | 197 | fs/nfs/inode.c | if (!(inode = iget(sb, fattr->fileid))) { |
inode | 201 | fs/nfs/inode.c | if (inode->i_dev == sb->s_dev) { |
inode | 202 | fs/nfs/inode.c | if (inode->i_ino != fattr->fileid) { |
inode | 204 | fs/nfs/inode.c | return inode; |
inode | 206 | fs/nfs/inode.c | *NFS_FH(inode) = *fhandle; |
inode | 207 | fs/nfs/inode.c | nfs_refresh_inode(inode, fattr); |
inode | 209 | fs/nfs/inode.c | return inode; |
inode | 212 | fs/nfs/inode.c | int nfs_notify_change(struct inode *inode, struct iattr *attr) |
inode | 234 | fs/nfs/inode.c | sattr.size = S_ISREG(inode->i_mode) ? attr->ia_size : -1; |
inode | 250 | fs/nfs/inode.c | error = nfs_proc_setattr(NFS_SERVER(inode), NFS_FH(inode), |
inode | 253 | fs/nfs/inode.c | nfs_refresh_inode(inode, &fattr); |
inode | 254 | fs/nfs/inode.c | inode->i_dirt = 0; |
inode | 36 | fs/nfs/mmap.c | struct inode * inode = area->vm_inode; |
inode | 52 | fs/nfs/mmap.c | n = NFS_SERVER(inode)->rsize; /* what we can read in one go */ |
inode | 60 | fs/nfs/mmap.c | result = nfs_proc_read(NFS_SERVER(inode), NFS_FH(inode), |
inode | 72 | fs/nfs/mmap.c | nfs_refresh_inode(inode, &fattr); |
inode | 97 | fs/nfs/mmap.c | int nfs_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 101 | fs/nfs/mmap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 103 | fs/nfs/mmap.c | if (!IS_RDONLY(inode)) { |
inode | 104 | fs/nfs/mmap.c | inode->i_atime = CURRENT_TIME; |
inode | 105 | fs/nfs/mmap.c | inode->i_dirt = 1; |
inode | 108 | fs/nfs/mmap.c | vma->vm_inode = inode; |
inode | 109 | fs/nfs/mmap.c | inode->i_count++; |
inode | 55 | fs/nfs/sock.c | struct inode *inode; |
inode | 63 | fs/nfs/sock.c | int (*select) (struct inode *, struct file *, int, select_table *); |
inode | 79 | fs/nfs/sock.c | inode = file->f_inode; |
inode | 81 | fs/nfs/sock.c | sock = &inode->u.socket_i; |
inode | 114 | fs/nfs/sock.c | if (!select(inode, file, SEL_IN, &wait_table) |
inode | 115 | fs/nfs/sock.c | && !select(inode, file, SEL_IN, NULL)) { |
inode | 25 | fs/nfs/symlink.c | static int nfs_readlink(struct inode *, char *, int); |
inode | 26 | fs/nfs/symlink.c | static int nfs_follow_link(struct inode *, struct inode *, int, int, |
inode | 27 | fs/nfs/symlink.c | struct inode **); |
inode | 50 | fs/nfs/symlink.c | static int nfs_follow_link(struct inode *dir, struct inode *inode, |
inode | 51 | fs/nfs/symlink.c | int flag, int mode, struct inode **res_inode) |
inode | 62 | fs/nfs/symlink.c | if (!inode) { |
inode | 66 | fs/nfs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 68 | fs/nfs/symlink.c | *res_inode = inode; |
inode | 72 | fs/nfs/symlink.c | iput(inode); |
inode | 76 | fs/nfs/symlink.c | error = nfs_proc_readlink(NFS_SERVER(inode), NFS_FH(inode), &mem, |
inode | 79 | fs/nfs/symlink.c | iput(inode); |
inode | 90 | fs/nfs/symlink.c | iput(inode); |
inode | 98 | fs/nfs/symlink.c | static int nfs_readlink(struct inode *inode, char *buffer, int buflen) |
inode | 104 | fs/nfs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 105 | fs/nfs/symlink.c | iput(inode); |
inode | 110 | fs/nfs/symlink.c | error = nfs_proc_readlink(NFS_SERVER(inode), NFS_FH(inode), &mem, |
inode | 112 | fs/nfs/symlink.c | iput(inode); |
inode | 32 | fs/open.c | struct inode * inode; |
inode | 38 | fs/open.c | error = namei(path,&inode); |
inode | 41 | fs/open.c | if (!inode->i_sb->s_op->statfs) { |
inode | 42 | fs/open.c | iput(inode); |
inode | 45 | fs/open.c | inode->i_sb->s_op->statfs(inode->i_sb, buf); |
inode | 46 | fs/open.c | iput(inode); |
inode | 52 | fs/open.c | struct inode * inode; |
inode | 61 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 63 | fs/open.c | if (!inode->i_sb->s_op->statfs) |
inode | 65 | fs/open.c | inode->i_sb->s_op->statfs(inode->i_sb, buf); |
inode | 71 | fs/open.c | struct inode * inode; |
inode | 75 | fs/open.c | error = namei(path,&inode); |
inode | 78 | fs/open.c | if (S_ISDIR(inode->i_mode)) { |
inode | 79 | fs/open.c | iput(inode); |
inode | 82 | fs/open.c | if ((error = permission(inode,MAY_WRITE)) != 0) { |
inode | 83 | fs/open.c | iput(inode); |
inode | 86 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 87 | fs/open.c | iput(inode); |
inode | 90 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) { |
inode | 91 | fs/open.c | iput(inode); |
inode | 94 | fs/open.c | error = get_write_access(inode); |
inode | 96 | fs/open.c | iput(inode); |
inode | 99 | fs/open.c | inode->i_size = newattrs.ia_size = length; |
inode | 100 | fs/open.c | if (inode->i_op && inode->i_op->truncate) |
inode | 101 | fs/open.c | inode->i_op->truncate(inode); |
inode | 104 | fs/open.c | inode->i_dirt = 1; |
inode | 105 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 106 | fs/open.c | put_write_access(inode); |
inode | 107 | fs/open.c | iput(inode); |
inode | 113 | fs/open.c | struct inode * inode; |
inode | 119 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 121 | fs/open.c | if (S_ISDIR(inode->i_mode) || !(file->f_mode & 2)) |
inode | 123 | fs/open.c | if (IS_IMMUTABLE(inode) || IS_APPEND(inode)) |
inode | 125 | fs/open.c | inode->i_size = newattrs.ia_size = length; |
inode | 126 | fs/open.c | if (inode->i_op && inode->i_op->truncate) |
inode | 127 | fs/open.c | inode->i_op->truncate(inode); |
inode | 130 | fs/open.c | inode->i_dirt = 1; |
inode | 131 | fs/open.c | return notify_change(inode, &newattrs); |
inode | 140 | fs/open.c | struct inode * inode; |
inode | 146 | fs/open.c | error = namei(filename,&inode); |
inode | 149 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 150 | fs/open.c | iput(inode); |
inode | 157 | fs/open.c | iput(inode); |
inode | 165 | fs/open.c | if ((error = permission(inode,MAY_WRITE)) != 0) { |
inode | 166 | fs/open.c | iput(inode); |
inode | 174 | fs/open.c | inode->i_dirt = 1; |
inode | 175 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 176 | fs/open.c | iput(inode); |
inode | 186 | fs/open.c | struct inode * inode; |
inode | 196 | fs/open.c | res = namei(filename,&inode); |
inode | 198 | fs/open.c | res = permission(inode, mode); |
inode | 199 | fs/open.c | iput(inode); |
inode | 208 | fs/open.c | struct inode * inode; |
inode | 211 | fs/open.c | error = namei(filename,&inode); |
inode | 214 | fs/open.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 215 | fs/open.c | iput(inode); |
inode | 218 | fs/open.c | if ((error = permission(inode,MAY_EXEC)) != 0) { |
inode | 219 | fs/open.c | iput(inode); |
inode | 223 | fs/open.c | current->fs->pwd = inode; |
inode | 229 | fs/open.c | struct inode * inode; |
inode | 235 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 237 | fs/open.c | if (!S_ISDIR(inode->i_mode)) |
inode | 239 | fs/open.c | if ((error = permission(inode,MAY_EXEC)) != 0) |
inode | 242 | fs/open.c | current->fs->pwd = inode; |
inode | 243 | fs/open.c | inode->i_count++; |
inode | 249 | fs/open.c | struct inode * inode; |
inode | 252 | fs/open.c | error = namei(filename,&inode); |
inode | 255 | fs/open.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 256 | fs/open.c | iput(inode); |
inode | 260 | fs/open.c | iput(inode); |
inode | 264 | fs/open.c | current->fs->root = inode; |
inode | 270 | fs/open.c | struct inode * inode; |
inode | 276 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 278 | fs/open.c | if (IS_RDONLY(inode)) |
inode | 281 | fs/open.c | mode = inode->i_mode; |
inode | 282 | fs/open.c | newattrs.ia_mode = (mode & S_IALLUGO) | (inode->i_mode & ~S_IALLUGO); |
inode | 285 | fs/open.c | inode->i_dirt = 1; |
inode | 286 | fs/open.c | return notify_change(inode, &newattrs); |
inode | 291 | fs/open.c | struct inode * inode; |
inode | 295 | fs/open.c | error = namei(filename,&inode); |
inode | 298 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 299 | fs/open.c | iput(inode); |
inode | 303 | fs/open.c | mode = inode->i_mode; |
inode | 304 | fs/open.c | newattrs.ia_mode = (mode & S_IALLUGO) | (inode->i_mode & ~S_IALLUGO); |
inode | 307 | fs/open.c | inode->i_dirt = 1; |
inode | 308 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 309 | fs/open.c | iput(inode); |
inode | 315 | fs/open.c | struct inode * inode; |
inode | 321 | fs/open.c | if (!(inode = file->f_inode)) |
inode | 323 | fs/open.c | if (IS_RDONLY(inode)) |
inode | 326 | fs/open.c | user = inode->i_uid; |
inode | 328 | fs/open.c | group = inode->i_gid; |
inode | 329 | fs/open.c | newattrs.ia_mode = inode->i_mode; |
inode | 337 | fs/open.c | if (user != inode->i_uid && (inode->i_mode & S_ISUID)) { |
inode | 344 | fs/open.c | if (group != inode->i_gid && (inode->i_mode & S_ISGID)) { |
inode | 348 | fs/open.c | inode->i_dirt = 1; |
inode | 349 | fs/open.c | return notify_change(inode, &newattrs); |
inode | 354 | fs/open.c | struct inode * inode; |
inode | 358 | fs/open.c | error = lnamei(filename,&inode); |
inode | 361 | fs/open.c | if (IS_RDONLY(inode)) { |
inode | 362 | fs/open.c | iput(inode); |
inode | 366 | fs/open.c | user = inode->i_uid; |
inode | 368 | fs/open.c | group = inode->i_gid; |
inode | 369 | fs/open.c | newattrs.ia_mode = inode->i_mode; |
inode | 377 | fs/open.c | if (user != inode->i_uid && (inode->i_mode & S_ISUID)) { |
inode | 384 | fs/open.c | if (group != inode->i_gid && (inode->i_mode & S_ISGID)) { |
inode | 388 | fs/open.c | inode->i_dirt = 1; |
inode | 389 | fs/open.c | error = notify_change(inode, &newattrs); |
inode | 390 | fs/open.c | iput(inode); |
inode | 410 | fs/open.c | struct inode * inode; |
inode | 430 | fs/open.c | error = open_namei(filename,flag,mode,&inode,NULL); |
inode | 432 | fs/open.c | error = get_write_access(inode); |
inode | 434 | fs/open.c | iput(inode); |
inode | 442 | fs/open.c | f->f_inode = inode; |
inode | 446 | fs/open.c | if (inode->i_op) |
inode | 447 | fs/open.c | f->f_op = inode->i_op->default_file_ops; |
inode | 449 | fs/open.c | error = f->f_op->open(inode,f); |
inode | 451 | fs/open.c | if (f->f_mode & 2) put_write_access(inode); |
inode | 452 | fs/open.c | iput(inode); |
inode | 482 | fs/open.c | struct inode *inode; |
inode | 488 | fs/open.c | inode = filp->f_inode; |
inode | 489 | fs/open.c | if (inode) |
inode | 496 | fs/open.c | filp->f_op->release(inode,filp); |
inode | 499 | fs/open.c | if (filp->f_mode & 2) put_write_access(inode); |
inode | 500 | fs/open.c | iput(inode); |
inode | 25 | fs/pipe.c | static int pipe_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 31 | fs/pipe.c | if (PIPE_LOCK(*inode)) |
inode | 33 | fs/pipe.c | if (PIPE_EMPTY(*inode)) |
inode | 34 | fs/pipe.c | if (PIPE_WRITERS(*inode)) |
inode | 38 | fs/pipe.c | } else while (PIPE_EMPTY(*inode) || PIPE_LOCK(*inode)) { |
inode | 39 | fs/pipe.c | if (PIPE_EMPTY(*inode)) { |
inode | 40 | fs/pipe.c | if (!PIPE_WRITERS(*inode)) |
inode | 45 | fs/pipe.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 47 | fs/pipe.c | PIPE_LOCK(*inode)++; |
inode | 48 | fs/pipe.c | while (count>0 && (size = PIPE_SIZE(*inode))) { |
inode | 49 | fs/pipe.c | chars = PIPE_MAX_RCHUNK(*inode); |
inode | 55 | fs/pipe.c | pipebuf = PIPE_BASE(*inode)+PIPE_START(*inode); |
inode | 56 | fs/pipe.c | PIPE_START(*inode) += chars; |
inode | 57 | fs/pipe.c | PIPE_START(*inode) &= (PIPE_BUF-1); |
inode | 58 | fs/pipe.c | PIPE_LEN(*inode) -= chars; |
inode | 63 | fs/pipe.c | PIPE_LOCK(*inode)--; |
inode | 64 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 67 | fs/pipe.c | if (PIPE_WRITERS(*inode)) |
inode | 72 | fs/pipe.c | static int pipe_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 77 | fs/pipe.c | if (!PIPE_READERS(*inode)) { /* no readers */ |
inode | 87 | fs/pipe.c | while ((PIPE_FREE(*inode) < free) || PIPE_LOCK(*inode)) { |
inode | 88 | fs/pipe.c | if (!PIPE_READERS(*inode)) { /* no readers */ |
inode | 96 | fs/pipe.c | interruptible_sleep_on(&PIPE_WAIT(*inode)); |
inode | 98 | fs/pipe.c | PIPE_LOCK(*inode)++; |
inode | 99 | fs/pipe.c | while (count>0 && (free = PIPE_FREE(*inode))) { |
inode | 100 | fs/pipe.c | chars = PIPE_MAX_WCHUNK(*inode); |
inode | 105 | fs/pipe.c | pipebuf = PIPE_BASE(*inode)+PIPE_END(*inode); |
inode | 107 | fs/pipe.c | PIPE_LEN(*inode) += chars; |
inode | 112 | fs/pipe.c | PIPE_LOCK(*inode)--; |
inode | 113 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 119 | fs/pipe.c | static int pipe_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 124 | fs/pipe.c | static int pipe_readdir(struct inode * inode, struct file * file, struct dirent * de, int count) |
inode | 129 | fs/pipe.c | static int bad_pipe_rw(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 134 | fs/pipe.c | static int pipe_ioctl(struct inode *pino, struct file * filp, |
inode | 150 | fs/pipe.c | static int pipe_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 154 | fs/pipe.c | if (!PIPE_EMPTY(*inode) || !PIPE_WRITERS(*inode)) |
inode | 156 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 159 | fs/pipe.c | if (!PIPE_FULL(*inode) || !PIPE_READERS(*inode)) |
inode | 161 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 164 | fs/pipe.c | if (!PIPE_READERS(*inode) || !PIPE_WRITERS(*inode)) |
inode | 166 | fs/pipe.c | select_wait(&inode->i_wait,wait); |
inode | 176 | fs/pipe.c | static int fifo_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 180 | fs/pipe.c | if (!PIPE_EMPTY(*inode)) |
inode | 182 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 185 | fs/pipe.c | if (!PIPE_FULL(*inode) || !PIPE_READERS(*inode)) |
inode | 187 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 190 | fs/pipe.c | if (!PIPE_READERS(*inode) || !PIPE_WRITERS(*inode)) |
inode | 192 | fs/pipe.c | select_wait(&inode->i_wait,wait); |
inode | 203 | fs/pipe.c | static int connect_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 205 | fs/pipe.c | while (!PIPE_SIZE(*inode)) { |
inode | 206 | fs/pipe.c | if (PIPE_WRITERS(*inode)) |
inode | 210 | fs/pipe.c | wake_up_interruptible(& PIPE_WAIT(*inode)); |
inode | 213 | fs/pipe.c | interruptible_sleep_on(& PIPE_WAIT(*inode)); |
inode | 216 | fs/pipe.c | return pipe_read(inode,filp,buf,count); |
inode | 219 | fs/pipe.c | static int connect_select(struct inode * inode, struct file * filp, int sel_type, select_table * wait) |
inode | 223 | fs/pipe.c | if (!PIPE_EMPTY(*inode)) { |
inode | 227 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 230 | fs/pipe.c | if (!PIPE_FULL(*inode)) |
inode | 232 | fs/pipe.c | select_wait(&PIPE_WAIT(*inode), wait); |
inode | 235 | fs/pipe.c | if (!PIPE_READERS(*inode) || !PIPE_WRITERS(*inode)) |
inode | 237 | fs/pipe.c | select_wait(&inode->i_wait,wait); |
inode | 247 | fs/pipe.c | static void pipe_read_release(struct inode * inode, struct file * filp) |
inode | 249 | fs/pipe.c | PIPE_READERS(*inode)--; |
inode | 250 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 253 | fs/pipe.c | static void pipe_write_release(struct inode * inode, struct file * filp) |
inode | 255 | fs/pipe.c | PIPE_WRITERS(*inode)--; |
inode | 256 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 259 | fs/pipe.c | static void pipe_rdwr_release(struct inode * inode, struct file * filp) |
inode | 261 | fs/pipe.c | PIPE_READERS(*inode)--; |
inode | 262 | fs/pipe.c | PIPE_WRITERS(*inode)--; |
inode | 263 | fs/pipe.c | wake_up_interruptible(&PIPE_WAIT(*inode)); |
inode | 381 | fs/pipe.c | struct inode * inode; |
inode | 409 | fs/pipe.c | if (!(inode=get_pipe_inode())) { |
inode | 416 | 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 | 124 | fs/proc/array.c | static int read_profile(struct inode *inode, struct file *file, char *buf, int count) |
inode | 151 | fs/proc/array.c | static int write_profile(struct inode * inode, struct file * file, char * buf, int count) |
inode | 834 | fs/proc/array.c | static int array_read(struct inode * inode, struct file * file,char * buf, int count) |
inode | 845 | fs/proc/array.c | type = inode->i_ino; |
inode | 897 | fs/proc/array.c | static int arraylong_read (struct inode * inode, struct file * file, char * buf, int count) |
inode | 899 | fs/proc/array.c | unsigned int pid = inode->i_ino >> 16; |
inode | 900 | fs/proc/array.c | unsigned int type = inode->i_ino & 0x0000ffff; |
inode | 16 | fs/proc/base.c | static int proc_readbase(struct inode *, struct file *, struct dirent *, int); |
inode | 17 | fs/proc/base.c | static int proc_lookupbase(struct inode *,const char *,int,struct inode **); |
inode | 82 | fs/proc/base.c | static int proc_lookupbase(struct inode * dir,const char * name, int len, |
inode | 83 | fs/proc/base.c | struct inode ** result) |
inode | 123 | fs/proc/base.c | static int proc_readbase(struct inode * inode, struct file * filp, |
inode | 130 | fs/proc/base.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 132 | fs/proc/base.c | ino = inode->i_ino; |
inode | 16 | fs/proc/fd.c | static int proc_readfd(struct inode *, struct file *, struct dirent *, int); |
inode | 17 | fs/proc/fd.c | static int proc_lookupfd(struct inode *,const char *,int,struct inode **); |
inode | 53 | fs/proc/fd.c | static int proc_lookupfd(struct inode * dir,const char * name, int len, |
inode | 54 | fs/proc/fd.c | struct inode ** result) |
inode | 117 | fs/proc/fd.c | static int proc_readfd(struct inode * inode, struct file * filp, |
inode | 124 | fs/proc/fd.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 126 | fs/proc/fd.c | ino = inode->i_ino; |
inode | 137 | fs/proc/fd.c | fd = inode->i_ino; |
inode | 139 | fs/proc/fd.c | fd = (inode->i_ino & 0xffff0000) | PROC_PID_INO; |
inode | 22 | fs/proc/inode.c | void proc_put_inode(struct inode *inode) |
inode | 24 | fs/proc/inode.c | if (inode->i_nlink) |
inode | 26 | fs/proc/inode.c | inode->i_size = 0; |
inode | 109 | fs/proc/inode.c | void proc_read_inode(struct inode * inode) |
inode | 115 | fs/proc/inode.c | inode->i_op = NULL; |
inode | 116 | fs/proc/inode.c | inode->i_mode = 0; |
inode | 117 | fs/proc/inode.c | inode->i_uid = 0; |
inode | 118 | fs/proc/inode.c | inode->i_gid = 0; |
inode | 119 | fs/proc/inode.c | inode->i_nlink = 1; |
inode | 120 | fs/proc/inode.c | inode->i_size = 0; |
inode | 121 | fs/proc/inode.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 122 | fs/proc/inode.c | inode->i_blocks = 0; |
inode | 123 | fs/proc/inode.c | inode->i_blksize = 1024; |
inode | 124 | fs/proc/inode.c | ino = inode->i_ino; |
inode | 133 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO; |
inode | 134 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 137 | fs/proc/inode.c | inode->i_nlink++; |
inode | 138 | fs/proc/inode.c | inode->i_op = &proc_root_inode_operations; |
inode | 145 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO | S_IWUSR; |
inode | 146 | fs/proc/inode.c | inode->i_op = &proc_net_inode_operations; |
inode | 153 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO | S_IWUSR; |
inode | 154 | fs/proc/inode.c | inode->i_op = &proc_net_inode_operations; |
inode | 161 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO; |
inode | 162 | fs/proc/inode.c | inode->i_op = &proc_net_inode_operations; |
inode | 169 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR; |
inode | 170 | fs/proc/inode.c | inode->i_op = &proc_kmsg_inode_operations; |
inode | 173 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO; |
inode | 174 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 175 | fs/proc/inode.c | inode->i_op = &proc_net_inode_operations; |
inode | 178 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR; |
inode | 179 | fs/proc/inode.c | inode->i_op = &proc_kcore_inode_operations; |
inode | 180 | fs/proc/inode.c | inode->i_size = high_memory + 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 | 190 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUGO; |
inode | 191 | 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 | 201 | fs/proc/inode.c | inode->i_nlink = 4; |
inode | 202 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUGO | S_IXUGO; |
inode | 203 | fs/proc/inode.c | inode->i_op = &proc_base_inode_operations; |
inode | 206 | fs/proc/inode.c | inode->i_op = &proc_mem_inode_operations; |
inode | 207 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR | S_IWUSR; |
inode | 212 | fs/proc/inode.c | inode->i_op = &proc_link_inode_operations; |
inode | 213 | fs/proc/inode.c | inode->i_size = 64; |
inode | 214 | fs/proc/inode.c | inode->i_mode = S_IFLNK | S_IRWXU; |
inode | 217 | fs/proc/inode.c | inode->i_mode = S_IFDIR | S_IRUSR | S_IXUSR; |
inode | 218 | fs/proc/inode.c | inode->i_op = &proc_fd_inode_operations; |
inode | 219 | fs/proc/inode.c | inode->i_nlink = 2; |
inode | 222 | fs/proc/inode.c | inode->i_mode = S_IFREG | S_IRUSR; |
inode | 223 | 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 | 21 | fs/proc/link.c | static int proc_fd_dupf(struct inode * inode, struct file * f); |
inode | 66 | fs/proc/link.c | static int proc_fd_dupf(struct inode * inode, struct file * f) |
inode | 79 | fs/proc/link.c | ino = inode->i_ino; |
inode | 101 | fs/proc/link.c | static int proc_follow_link(struct inode * dir, struct inode * inode, |
inode | 102 | fs/proc/link.c | int flag, int mode, struct inode ** res_inode) |
inode | 106 | fs/proc/link.c | struct inode * new_inode; |
inode | 112 | fs/proc/link.c | if (!inode) |
inode | 114 | fs/proc/link.c | if ((error = permission(inode, MAY_EXEC)) != 0){ |
inode | 115 | fs/proc/link.c | iput(inode); |
inode | 118 | fs/proc/link.c | ino = inode->i_ino; |
inode | 125 | fs/proc/link.c | iput(inode); |
inode | 154 | fs/proc/link.c | *res_inode = inode; |
inode | 163 | fs/proc/link.c | iput(inode); |
inode | 171 | fs/proc/link.c | static int proc_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 177 | fs/proc/link.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 178 | fs/proc/link.c | iput(inode); |
inode | 181 | fs/proc/link.c | i = proc_follow_link(NULL, inode, 0, 0, &inode); |
inode | 184 | fs/proc/link.c | if (!inode) |
inode | 186 | fs/proc/link.c | dev = inode->i_dev; |
inode | 187 | fs/proc/link.c | ino = inode->i_ino; |
inode | 188 | fs/proc/link.c | iput(inode); |
inode | 27 | fs/proc/mem.c | static int mem_read(struct inode * inode, struct file * file,char * buf, int count) |
inode | 40 | fs/proc/mem.c | pid = inode->i_ino; |
inode | 89 | fs/proc/mem.c | static int mem_write(struct inode * inode, struct file * file,char * buf, int count) |
inode | 103 | fs/proc/mem.c | pid = inode->i_ino; |
inode | 157 | fs/proc/mem.c | static int mem_lseek(struct inode * inode, struct file * file, off_t offset, int orig) |
inode | 174 | fs/proc/mem.c | int mem_mmap(struct inode * inode, struct file * file, |
inode | 189 | fs/proc/mem.c | if (task[i] && task[i]->pid == (inode->i_ino >> 16)) { |
inode | 40 | fs/proc/net.c | static int proc_readnet(struct inode * inode, struct file * file, |
inode | 42 | fs/proc/net.c | static int proc_readnetdir(struct inode *, struct file *, |
inode | 44 | fs/proc/net.c | static int proc_lookupnet(struct inode *,const char *,int,struct inode **); |
inode | 184 | fs/proc/net.c | static int proc_lookupnet(struct inode * dir,const char * name, int len, |
inode | 185 | fs/proc/net.c | struct inode ** result) |
inode | 209 | fs/proc/net.c | static int proc_readnetdir(struct inode * inode, struct file * filp, |
inode | 216 | fs/proc/net.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 218 | fs/proc/net.c | ino = inode->i_ino; |
inode | 238 | fs/proc/net.c | static int proc_readnet(struct inode * inode, struct file * file, |
inode | 253 | fs/proc/net.c | ino = inode->i_ino; |
inode | 17 | fs/proc/root.c | static int proc_readroot(struct inode *, struct file *, struct dirent *, int); |
inode | 18 | fs/proc/root.c | static int proc_lookuproot(struct inode *,const char *,int,struct inode **); |
inode | 87 | fs/proc/root.c | static int proc_lookuproot(struct inode * dir,const char * name, int len, |
inode | 88 | fs/proc/root.c | struct inode ** result) |
inode | 144 | fs/proc/root.c | static int proc_readroot(struct inode * inode, struct file * filp, |
inode | 151 | fs/proc/root.c | if (!inode || !S_ISDIR(inode->i_mode)) |
inode | 30 | fs/read_write.c | struct inode * inode; |
inode | 33 | fs/read_write.c | !(inode = file->f_inode)) |
inode | 42 | fs/read_write.c | error = file->f_op->readdir(inode,file,dirent,count); |
inode | 126 | fs/read_write.c | struct inode * inode; |
inode | 128 | fs/read_write.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 139 | fs/read_write.c | return file->f_op->read(inode,file,buf,count); |
inode | 146 | fs/read_write.c | struct inode * inode; |
inode | 149 | fs/read_write.c | if (fd>=NR_OPEN || !(file=current->files->fd[fd]) || !(inode=file->f_inode)) |
inode | 160 | fs/read_write.c | written = file->f_op->write(inode,file,buf,count); |
inode | 165 | fs/read_write.c | if (written > 0 && !suser() && (inode->i_mode & (S_ISUID | S_ISGID))) { |
inode | 167 | fs/read_write.c | newattrs.ia_mode = inode->i_mode & ~(S_ISUID | S_ISGID); |
inode | 169 | fs/read_write.c | notify_change(inode, &newattrs); |
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 | 17 | fs/stat.c | static void cp_old_stat(struct inode * inode, struct old_stat * statbuf) |
inode | 23 | fs/stat.c | tmp.st_dev = inode->i_dev; |
inode | 24 | fs/stat.c | tmp.st_ino = inode->i_ino; |
inode | 25 | fs/stat.c | tmp.st_mode = inode->i_mode; |
inode | 26 | fs/stat.c | tmp.st_nlink = inode->i_nlink; |
inode | 27 | fs/stat.c | tmp.st_uid = inode->i_uid; |
inode | 28 | fs/stat.c | tmp.st_gid = inode->i_gid; |
inode | 29 | fs/stat.c | tmp.st_rdev = inode->i_rdev; |
inode | 30 | fs/stat.c | tmp.st_size = inode->i_size; |
inode | 31 | fs/stat.c | if (inode->i_pipe) |
inode | 32 | fs/stat.c | tmp.st_size = PIPE_SIZE(*inode); |
inode | 33 | fs/stat.c | tmp.st_atime = inode->i_atime; |
inode | 34 | fs/stat.c | tmp.st_mtime = inode->i_mtime; |
inode | 35 | fs/stat.c | tmp.st_ctime = inode->i_ctime; |
inode | 39 | fs/stat.c | static void cp_new_stat(struct inode * inode, struct new_stat * statbuf) |
inode | 45 | fs/stat.c | tmp.st_dev = inode->i_dev; |
inode | 46 | fs/stat.c | tmp.st_ino = inode->i_ino; |
inode | 47 | fs/stat.c | tmp.st_mode = inode->i_mode; |
inode | 48 | fs/stat.c | tmp.st_nlink = inode->i_nlink; |
inode | 49 | fs/stat.c | tmp.st_uid = inode->i_uid; |
inode | 50 | fs/stat.c | tmp.st_gid = inode->i_gid; |
inode | 51 | fs/stat.c | tmp.st_rdev = inode->i_rdev; |
inode | 52 | fs/stat.c | tmp.st_size = inode->i_size; |
inode | 53 | fs/stat.c | if (inode->i_pipe) |
inode | 54 | fs/stat.c | tmp.st_size = PIPE_SIZE(*inode); |
inode | 55 | fs/stat.c | tmp.st_atime = inode->i_atime; |
inode | 56 | fs/stat.c | tmp.st_mtime = inode->i_mtime; |
inode | 57 | fs/stat.c | tmp.st_ctime = inode->i_ctime; |
inode | 76 | fs/stat.c | if (!inode->i_blksize) { |
inode | 91 | fs/stat.c | tmp.st_blocks = inode->i_blocks; |
inode | 92 | fs/stat.c | tmp.st_blksize = inode->i_blksize; |
inode | 99 | fs/stat.c | struct inode * inode; |
inode | 105 | fs/stat.c | error = namei(filename,&inode); |
inode | 108 | fs/stat.c | cp_old_stat(inode,statbuf); |
inode | 109 | fs/stat.c | iput(inode); |
inode | 115 | fs/stat.c | struct inode * inode; |
inode | 121 | fs/stat.c | error = namei(filename,&inode); |
inode | 124 | fs/stat.c | cp_new_stat(inode,statbuf); |
inode | 125 | fs/stat.c | iput(inode); |
inode | 131 | fs/stat.c | struct inode * inode; |
inode | 137 | fs/stat.c | error = lnamei(filename,&inode); |
inode | 140 | fs/stat.c | cp_old_stat(inode,statbuf); |
inode | 141 | fs/stat.c | iput(inode); |
inode | 147 | fs/stat.c | struct inode * inode; |
inode | 153 | fs/stat.c | error = lnamei(filename,&inode); |
inode | 156 | fs/stat.c | cp_new_stat(inode,statbuf); |
inode | 157 | fs/stat.c | iput(inode); |
inode | 164 | fs/stat.c | struct inode * inode; |
inode | 170 | fs/stat.c | if (fd >= NR_OPEN || !(f=current->files->fd[fd]) || !(inode=f->f_inode)) |
inode | 172 | fs/stat.c | cp_old_stat(inode,statbuf); |
inode | 179 | fs/stat.c | struct inode * inode; |
inode | 185 | fs/stat.c | if (fd >= NR_OPEN || !(f=current->files->fd[fd]) || !(inode=f->f_inode)) |
inode | 187 | fs/stat.c | cp_new_stat(inode,statbuf); |
inode | 193 | fs/stat.c | struct inode * inode; |
inode | 201 | fs/stat.c | error = lnamei(path,&inode); |
inode | 204 | fs/stat.c | if (!inode->i_op || !inode->i_op->readlink) { |
inode | 205 | fs/stat.c | iput(inode); |
inode | 208 | fs/stat.c | return inode->i_op->readlink(inode,buf,bufsiz); |
inode | 372 | fs/super.c | struct inode * inode; |
inode | 375 | fs/super.c | struct inode dummy_inode; |
inode | 380 | fs/super.c | retval = namei(name,&inode); |
inode | 382 | fs/super.c | retval = lnamei(name,&inode); |
inode | 386 | fs/super.c | if (S_ISBLK(inode->i_mode)) { |
inode | 387 | fs/super.c | dev = inode->i_rdev; |
inode | 388 | fs/super.c | if (IS_NODEV(inode)) { |
inode | 389 | fs/super.c | iput(inode); |
inode | 393 | fs/super.c | if (!inode->i_sb || inode != inode->i_sb->s_mounted) { |
inode | 394 | fs/super.c | iput(inode); |
inode | 397 | fs/super.c | dev = inode->i_sb->s_dev; |
inode | 398 | fs/super.c | iput(inode); |
inode | 401 | fs/super.c | inode = &dummy_inode; |
inode | 404 | fs/super.c | iput(inode); |
inode | 410 | fs/super.c | fops->release(inode,NULL); |
inode | 414 | fs/super.c | if (inode != &dummy_inode) |
inode | 415 | fs/super.c | iput(inode); |
inode | 433 | fs/super.c | struct inode * dir_i; |
inode | 496 | fs/super.c | struct inode *dir_i; |
inode | 553 | fs/super.c | struct inode * inode; |
inode | 584 | fs/super.c | retval = namei(dev_name,&inode); |
inode | 587 | fs/super.c | if (!S_ISBLK(inode->i_mode)) { |
inode | 588 | fs/super.c | iput(inode); |
inode | 591 | fs/super.c | if (IS_NODEV(inode)) { |
inode | 592 | fs/super.c | iput(inode); |
inode | 595 | fs/super.c | dev = inode->i_rdev; |
inode | 597 | fs/super.c | iput(inode); |
inode | 602 | fs/super.c | iput(inode); |
inode | 608 | fs/super.c | dummy.f_inode = inode; |
inode | 610 | fs/super.c | retval = fops->open(inode, &dummy); |
inode | 612 | fs/super.c | iput(inode); |
inode | 620 | fs/super.c | inode = NULL; |
inode | 627 | fs/super.c | iput(inode); |
inode | 634 | fs/super.c | fops->release(inode, NULL); |
inode | 635 | fs/super.c | iput(inode); |
inode | 643 | fs/super.c | struct inode * inode, d_inode; |
inode | 677 | fs/super.c | inode = sb->s_mounted; |
inode | 678 | fs/super.c | inode->i_count += 3 ; /* NOTE! it is logically used 4 times, not 1 */ |
inode | 679 | fs/super.c | sb->s_covered = inode; |
inode | 681 | fs/super.c | current->fs->pwd = inode; |
inode | 682 | fs/super.c | current->fs->root = inode; |
inode | 30 | fs/sysv/dir.c | static int sysv_dir_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 35 | fs/sysv/dir.c | static int sysv_readdir(struct inode *, struct file *, struct dirent *, int); |
inode | 71 | fs/sysv/dir.c | static int sysv_readdir1 (struct inode * inode, struct file * filp, |
inode | 81 | fs/sysv/dir.c | if (!inode || !(sb = inode->i_sb) || !S_ISDIR(inode->i_mode)) |
inode | 85 | fs/sysv/dir.c | while (filp->f_pos < inode->i_size) { |
inode | 87 | fs/sysv/dir.c | bh = sysv_file_bread(inode, filp->f_pos >> sb->sv_block_size_bits, 0); |
inode | 93 | fs/sysv/dir.c | while (offset < sb->sv_block_size && filp->f_pos < inode->i_size) { |
inode | 97 | fs/sysv/dir.c | if (de->inode) { |
inode | 111 | fs/sysv/dir.c | if (sde.inode > inode->i_sb->sv_ninodes) |
inode | 113 | fs/sysv/dir.c | inode->i_dev, inode->i_ino, (off_t) filp->f_pos - SYSV_DIRSIZE, sde.inode); |
inode | 114 | fs/sysv/dir.c | put_fs_long(sde.inode,&dirent->d_ino); |
inode | 127 | fs/sysv/dir.c | static int sysv_readdir(struct inode * inode, struct file * filp, |
inode | 134 | fs/sysv/dir.c | return sysv_readdir1(inode,filp,dirent); |
inode | 138 | fs/sysv/dir.c | retval = sysv_readdir1(inode,filp,dirent); |
inode | 39 | fs/sysv/file.c | static int sysv_file_write(struct inode *, struct file *, char *, int); |
inode | 76 | fs/sysv/file.c | int sysv_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 78 | fs/sysv/file.c | struct super_block * sb = inode->i_sb; |
inode | 88 | fs/sysv/file.c | if (!inode) { |
inode | 92 | fs/sysv/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 93 | fs/sysv/file.c | printk("sysv_file_read: mode = %07o\n",inode->i_mode); |
inode | 97 | fs/sysv/file.c | size = inode->i_size; |
inode | 113 | fs/sysv/file.c | blocks += read_ahead[MAJOR(inode->i_dev)] >> (sb->sv_block_size_bits - 9); |
inode | 134 | fs/sysv/file.c | *bhb = sysv_getblk(inode, block++, 0); |
inode | 196 | fs/sysv/file.c | if (!IS_RDONLY(inode)) { |
inode | 197 | fs/sysv/file.c | inode->i_atime = CURRENT_TIME; |
inode | 198 | fs/sysv/file.c | inode->i_dirt = 1; |
inode | 203 | fs/sysv/file.c | static int sysv_file_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 205 | fs/sysv/file.c | struct super_block * sb = inode->i_sb; |
inode | 211 | fs/sysv/file.c | if (!inode) { |
inode | 215 | fs/sysv/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 216 | fs/sysv/file.c | printk("sysv_file_write: mode = %07o\n",inode->i_mode); |
inode | 227 | fs/sysv/file.c | pos = inode->i_size; |
inode | 232 | fs/sysv/file.c | bh = sysv_getblk (inode, pos >> sb->sv_block_size_bits, 1); |
inode | 254 | fs/sysv/file.c | if (pos > inode->i_size) { |
inode | 255 | fs/sysv/file.c | inode->i_size = pos; |
inode | 256 | 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 | 33 | fs/sysv/fsync.c | static int sync_block (struct inode * inode, unsigned long * blockp, int convert, int wait) |
inode | 44 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 45 | fs/sysv/fsync.c | bh = sv_get_hash_table(sb, inode->i_dev, block); |
inode | 66 | fs/sysv/fsync.c | static int sync_iblock (struct inode * inode, unsigned long * iblockp, int convert, |
inode | 78 | fs/sysv/fsync.c | rc = sync_block (inode, iblockp, convert, wait); |
inode | 81 | fs/sysv/fsync.c | *bh = sv_bread(inode->i_sb, inode->i_dev, block); |
inode | 93 | fs/sysv/fsync.c | static int sync_direct(struct inode *inode, int wait) |
inode | 99 | fs/sysv/fsync.c | rc = sync_block (inode, inode->u.sysv_i.i_data + i, 0, wait); |
inode | 108 | fs/sysv/fsync.c | static int sync_indirect(struct inode *inode, unsigned long *iblockp, int convert, int wait) |
inode | 115 | fs/sysv/fsync.c | rc = sync_iblock (inode, iblockp, convert, &ind_bh, wait); |
inode | 119 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 121 | fs/sysv/fsync.c | rc = sync_block (inode, |
inode | 133 | fs/sysv/fsync.c | static int sync_dindirect(struct inode *inode, unsigned long *diblockp, int convert, |
inode | 141 | fs/sysv/fsync.c | rc = sync_iblock (inode, diblockp, convert, &dind_bh, wait); |
inode | 145 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 147 | fs/sysv/fsync.c | rc = sync_indirect (inode, |
inode | 159 | fs/sysv/fsync.c | static int sync_tindirect(struct inode *inode, unsigned long *tiblockp, int convert, |
inode | 167 | fs/sysv/fsync.c | rc = sync_iblock (inode, tiblockp, convert, &tind_bh, wait); |
inode | 171 | fs/sysv/fsync.c | sb = inode->i_sb; |
inode | 173 | fs/sysv/fsync.c | rc = sync_dindirect (inode, |
inode | 185 | fs/sysv/fsync.c | int sysv_sync_file(struct inode * inode, struct file * file) |
inode | 189 | fs/sysv/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 190 | fs/sysv/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 194 | fs/sysv/fsync.c | err |= sync_direct(inode, wait); |
inode | 195 | fs/sysv/fsync.c | err |= sync_indirect(inode, inode->u.sysv_i.i_data+10, 0, wait); |
inode | 196 | fs/sysv/fsync.c | err |= sync_dindirect(inode, inode->u.sysv_i.i_data+11, 0, wait); |
inode | 197 | fs/sysv/fsync.c | err |= sync_tindirect(inode, inode->u.sysv_i.i_data+12, 0, wait); |
inode | 199 | fs/sysv/fsync.c | err |= sysv_sync_inode (inode); |
inode | 56 | fs/sysv/ialloc.c | void sysv_free_inode(struct inode * inode) |
inode | 63 | fs/sysv/ialloc.c | if (!inode) |
inode | 65 | fs/sysv/ialloc.c | if (!inode->i_dev) { |
inode | 69 | fs/sysv/ialloc.c | if (inode->i_count != 1) { |
inode | 70 | fs/sysv/ialloc.c | printk("sysv_free_inode: inode has count=%d\n", inode->i_count); |
inode | 73 | fs/sysv/ialloc.c | if (inode->i_nlink) { |
inode | 74 | fs/sysv/ialloc.c | printk("sysv_free_inode: inode has nlink=%d\n", inode->i_nlink); |
inode | 77 | fs/sysv/ialloc.c | if (!(sb = inode->i_sb)) { |
inode | 81 | fs/sysv/ialloc.c | ino = inode->i_ino; |
inode | 86 | fs/sysv/ialloc.c | if (!(bh = sv_bread(sb, inode->i_dev, sb->sv_firstinodezone + ((ino-1) >> sb->sv_inodes_per_block_bits)))) { |
inode | 87 | fs/sysv/ialloc.c | printk("sysv_free_inode: unable to read inode block on device %d/%d\n",MAJOR(inode->i_dev),MINOR(inode->i_dev)); |
inode | 88 | fs/sysv/ialloc.c | clear_inode(inode); |
inode | 103 | fs/sysv/ialloc.c | clear_inode(inode); |
inode | 106 | fs/sysv/ialloc.c | struct inode * sysv_new_inode(const struct inode * dir) |
inode | 108 | fs/sysv/ialloc.c | struct inode * inode; |
inode | 114 | fs/sysv/ialloc.c | if (!dir || !(inode = get_empty_inode())) |
inode | 117 | fs/sysv/ialloc.c | inode->i_sb = sb; |
inode | 118 | fs/sysv/ialloc.c | inode->i_flags = inode->i_sb->s_flags; |
inode | 144 | fs/sysv/ialloc.c | iput(inode); |
inode | 155 | fs/sysv/ialloc.c | inode->i_count = 1; |
inode | 156 | fs/sysv/ialloc.c | inode->i_nlink = 1; |
inode | 157 | fs/sysv/ialloc.c | inode->i_dev = sb->s_dev; |
inode | 158 | fs/sysv/ialloc.c | inode->i_uid = current->fsuid; |
inode | 159 | fs/sysv/ialloc.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 160 | fs/sysv/ialloc.c | inode->i_dirt = 1; |
inode | 161 | fs/sysv/ialloc.c | inode->i_ino = ino; |
inode | 162 | fs/sysv/ialloc.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 163 | fs/sysv/ialloc.c | inode->i_op = NULL; |
inode | 164 | fs/sysv/ialloc.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 165 | fs/sysv/ialloc.c | insert_inode_hash(inode); |
inode | 167 | fs/sysv/ialloc.c | inode->i_mode = 0; /* for sysv_write_inode() */ |
inode | 168 | fs/sysv/ialloc.c | inode->i_size = 0; /* ditto */ |
inode | 169 | fs/sysv/ialloc.c | sysv_write_inode(inode); /* ensure inode not allocated again */ |
inode | 171 | fs/sysv/ialloc.c | inode->i_dirt = 1; /* cleared by sysv_write_inode() */ |
inode | 177 | fs/sysv/ialloc.c | return inode; |
inode | 41 | fs/sysv/inode.c | void sysv_put_inode(struct inode *inode) |
inode | 43 | fs/sysv/inode.c | if (inode->i_nlink) |
inode | 45 | fs/sysv/inode.c | inode->i_size = 0; |
inode | 46 | fs/sysv/inode.c | sysv_truncate(inode); |
inode | 47 | fs/sysv/inode.c | sysv_free_inode(inode); |
inode | 558 | fs/sysv/inode.c | static inline int inode_bmap(struct super_block * sb, struct inode * inode, int nr) |
inode | 560 | fs/sysv/inode.c | int tmp = inode->u.sysv_i.i_data[nr]; |
inode | 581 | fs/sysv/inode.c | int sysv_bmap(struct inode * inode,int block_nr) |
inode | 584 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 590 | fs/sysv/inode.c | return inode_bmap(sb,inode,block); |
inode | 594 | fs/sysv/inode.c | i = inode_bmap(sb,inode,10); |
inode | 597 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 602 | fs/sysv/inode.c | i = inode_bmap(sb,inode,11); |
inode | 605 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 609 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 614 | fs/sysv/inode.c | i = inode_bmap(sb,inode,12); |
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 | 625 | fs/sysv/inode.c | bh = bread(inode->i_dev,i,sb->sv_block_size); |
inode | 641 | fs/sysv/inode.c | static struct buffer_head * inode_getblk(struct inode * inode, int nr, int create) |
inode | 648 | fs/sysv/inode.c | sb = inode->i_sb; |
inode | 649 | fs/sysv/inode.c | p = inode->u.sysv_i.i_data + nr; |
inode | 653 | fs/sysv/inode.c | result = sv_getblk(sb, inode->i_dev, tmp); |
inode | 664 | fs/sysv/inode.c | result = sv_getblk(sb, inode->i_dev, tmp); |
inode | 671 | fs/sysv/inode.c | inode->i_ctime = CURRENT_TIME; |
inode | 672 | fs/sysv/inode.c | inode->i_dirt = 1; |
inode | 676 | fs/sysv/inode.c | static struct buffer_head * block_getblk(struct inode * inode, |
inode | 694 | fs/sysv/inode.c | sb = inode->i_sb; |
inode | 730 | fs/sysv/inode.c | struct buffer_head * sysv_getblk(struct inode * inode, unsigned int block, int create) |
inode | 732 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 736 | fs/sysv/inode.c | return inode_getblk(inode,block,create); |
inode | 739 | fs/sysv/inode.c | bh = inode_getblk(inode,10,create); |
inode | 740 | fs/sysv/inode.c | return block_getblk(inode, bh, block, create); |
inode | 744 | fs/sysv/inode.c | bh = inode_getblk(inode,11,create); |
inode | 745 | fs/sysv/inode.c | bh = block_getblk(inode, bh, block >> sb->sv_ind_per_block_bits, create); |
inode | 746 | fs/sysv/inode.c | return block_getblk(inode, bh, block & sb->sv_ind_per_block_1, create); |
inode | 750 | fs/sysv/inode.c | bh = inode_getblk(inode,12,create); |
inode | 751 | fs/sysv/inode.c | bh = block_getblk(inode, bh, block >> sb->sv_ind_per_block_2_bits, create); |
inode | 752 | fs/sysv/inode.c | bh = block_getblk(inode, bh, (block >> sb->sv_ind_per_block_bits) & sb->sv_ind_per_block_1, create); |
inode | 753 | fs/sysv/inode.c | return block_getblk(inode, bh, block & sb->sv_ind_per_block_1, create); |
inode | 763 | fs/sysv/inode.c | struct buffer_head * sysv_file_bread(struct inode * inode, int block, int create) |
inode | 767 | fs/sysv/inode.c | bh = sysv_getblk(inode,block,create); |
inode | 803 | fs/sysv/inode.c | void sysv_read_inode(struct inode * inode) |
inode | 805 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 811 | fs/sysv/inode.c | ino = inode->i_ino; |
inode | 812 | fs/sysv/inode.c | inode->i_op = NULL; |
inode | 813 | fs/sysv/inode.c | inode->i_mode = 0; |
inode | 816 | fs/sysv/inode.c | inode->i_dev, ino); |
inode | 820 | fs/sysv/inode.c | if (!(bh = sv_bread(sb,inode->i_dev,block))) { |
inode | 822 | fs/sysv/inode.c | inode->i_dev); |
inode | 830 | fs/sysv/inode.c | inode->i_mode = mode; |
inode | 831 | fs/sysv/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 832 | fs/sysv/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 833 | fs/sysv/inode.c | inode->i_nlink = raw_inode->i_nlink; |
inode | 835 | fs/sysv/inode.c | inode->i_size = from_coh_ulong(raw_inode->i_size); |
inode | 836 | fs/sysv/inode.c | inode->i_atime = from_coh_ulong(raw_inode->i_atime); |
inode | 837 | fs/sysv/inode.c | inode->i_mtime = from_coh_ulong(raw_inode->i_mtime); |
inode | 838 | fs/sysv/inode.c | inode->i_ctime = from_coh_ulong(raw_inode->i_ctime); |
inode | 840 | fs/sysv/inode.c | inode->i_size = raw_inode->i_size; |
inode | 841 | fs/sysv/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 842 | fs/sysv/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 843 | fs/sysv/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 845 | fs/sysv/inode.c | inode->i_blocks = inode->i_blksize = 0; |
inode | 846 | fs/sysv/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 847 | fs/sysv/inode.c | inode->i_rdev = raw_inode->i_a.i_rdev; |
inode | 851 | fs/sysv/inode.c | inode->u.sysv_i.i_data[block] = |
inode | 855 | fs/sysv/inode.c | inode->u.sysv_i.i_data[block] = |
inode | 858 | fs/sysv/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 859 | fs/sysv/inode.c | inode->i_op = &sysv_file_inode_operations; |
inode | 860 | fs/sysv/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 861 | fs/sysv/inode.c | inode->i_op = &sysv_dir_inode_operations; |
inode | 862 | fs/sysv/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 863 | fs/sysv/inode.c | inode->i_op = &sysv_symlink_inode_operations; |
inode | 864 | fs/sysv/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 865 | fs/sysv/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 866 | fs/sysv/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 867 | fs/sysv/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 868 | fs/sysv/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 869 | fs/sysv/inode.c | init_fifo(inode); |
inode | 873 | fs/sysv/inode.c | extern int sysv_notify_change(struct inode *inode, struct iattr *attr) |
inode | 877 | fs/sysv/inode.c | if ((error = inode_change_ok(inode, attr)) != 0) |
inode | 881 | fs/sysv/inode.c | if (inode->i_sb->sv_kludge_symlinks) |
inode | 885 | fs/sysv/inode.c | inode_setattr(inode, attr); |
inode | 890 | fs/sysv/inode.c | static struct buffer_head * sysv_update_inode(struct inode * inode) |
inode | 892 | fs/sysv/inode.c | struct super_block * sb = inode->i_sb; |
inode | 898 | fs/sysv/inode.c | ino = inode->i_ino; |
inode | 901 | fs/sysv/inode.c | inode->i_dev, ino); |
inode | 902 | fs/sysv/inode.c | inode->i_dirt = 0; |
inode | 906 | fs/sysv/inode.c | if (!(bh = sv_bread(sb,inode->i_dev,block))) { |
inode | 908 | fs/sysv/inode.c | inode->i_dirt = 0; |
inode | 912 | fs/sysv/inode.c | mode = inode->i_mode; |
inode | 916 | fs/sysv/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 917 | fs/sysv/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 918 | fs/sysv/inode.c | raw_inode->i_nlink = inode->i_nlink; |
inode | 920 | fs/sysv/inode.c | raw_inode->i_size = to_coh_ulong(inode->i_size); |
inode | 921 | fs/sysv/inode.c | raw_inode->i_atime = to_coh_ulong(inode->i_atime); |
inode | 922 | fs/sysv/inode.c | raw_inode->i_mtime = to_coh_ulong(inode->i_mtime); |
inode | 923 | fs/sysv/inode.c | raw_inode->i_ctime = to_coh_ulong(inode->i_ctime); |
inode | 925 | fs/sysv/inode.c | raw_inode->i_size = inode->i_size; |
inode | 926 | fs/sysv/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 927 | fs/sysv/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 928 | fs/sysv/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 930 | fs/sysv/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 931 | fs/sysv/inode.c | raw_inode->i_a.i_rdev = inode->i_rdev; /* write 2 or 3 bytes ?? */ |
inode | 935 | fs/sysv/inode.c | coh_write3byte(&raw_inode->i_a.i_addb[3*block],inode->u.sysv_i.i_data[block]); |
inode | 938 | fs/sysv/inode.c | write3byte(&raw_inode->i_a.i_addb[3*block],inode->u.sysv_i.i_data[block]); |
inode | 939 | fs/sysv/inode.c | inode->i_dirt=0; |
inode | 944 | fs/sysv/inode.c | void sysv_write_inode(struct inode * inode) |
inode | 947 | fs/sysv/inode.c | bh = sysv_update_inode(inode); |
inode | 951 | fs/sysv/inode.c | int sysv_sync_inode(struct inode * inode) |
inode | 956 | fs/sysv/inode.c | bh = sysv_update_inode(inode); |
inode | 963 | fs/sysv/inode.c | inode->i_dev, inode->i_ino); |
inode | 48 | fs/sysv/namei.c | if (!de->inode || len > SYSV_NAMELEN) |
inode | 64 | fs/sysv/namei.c | static struct buffer_head * sysv_find_entry(struct inode * dir, |
inode | 107 | fs/sysv/namei.c | int sysv_lookup(struct inode * dir,const char * name, int len, |
inode | 108 | fs/sysv/namei.c | struct inode ** result) |
inode | 125 | fs/sysv/namei.c | ino = de->inode; |
inode | 145 | fs/sysv/namei.c | static int sysv_add_entry(struct inode * dir, |
inode | 180 | fs/sysv/namei.c | de->inode = 0; |
inode | 184 | fs/sysv/namei.c | if (de->inode) { |
inode | 208 | fs/sysv/namei.c | int sysv_create(struct inode * dir,const char * name, int len, int mode, |
inode | 209 | fs/sysv/namei.c | struct inode ** result) |
inode | 212 | fs/sysv/namei.c | struct inode * inode; |
inode | 219 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
inode | 220 | fs/sysv/namei.c | if (!inode) { |
inode | 224 | fs/sysv/namei.c | inode->i_op = &sysv_file_inode_operations; |
inode | 225 | fs/sysv/namei.c | inode->i_mode = mode; |
inode | 226 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 229 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 230 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 231 | fs/sysv/namei.c | iput(inode); |
inode | 235 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 239 | fs/sysv/namei.c | *result = inode; |
inode | 243 | fs/sysv/namei.c | int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
inode | 246 | fs/sysv/namei.c | struct inode * inode; |
inode | 258 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
inode | 259 | fs/sysv/namei.c | if (!inode) { |
inode | 263 | fs/sysv/namei.c | inode->i_uid = current->fsuid; |
inode | 264 | fs/sysv/namei.c | inode->i_mode = mode; |
inode | 265 | fs/sysv/namei.c | inode->i_op = NULL; |
inode | 266 | fs/sysv/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 267 | fs/sysv/namei.c | inode->i_op = &sysv_file_inode_operations; |
inode | 268 | fs/sysv/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 269 | fs/sysv/namei.c | inode->i_op = &sysv_dir_inode_operations; |
inode | 271 | fs/sysv/namei.c | inode->i_mode |= S_ISGID; |
inode | 273 | fs/sysv/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 274 | fs/sysv/namei.c | inode->i_op = &sysv_symlink_inode_operations; |
inode | 275 | fs/sysv/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 276 | fs/sysv/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 277 | fs/sysv/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 278 | fs/sysv/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 279 | fs/sysv/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 280 | fs/sysv/namei.c | init_fifo(inode); |
inode | 282 | fs/sysv/namei.c | inode->i_rdev = rdev; |
inode | 283 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 286 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 287 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 288 | fs/sysv/namei.c | iput(inode); |
inode | 292 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 296 | fs/sysv/namei.c | iput(inode); |
inode | 300 | fs/sysv/namei.c | int sysv_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 303 | fs/sysv/namei.c | struct inode * inode; |
inode | 321 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
inode | 322 | fs/sysv/namei.c | if (!inode) { |
inode | 326 | fs/sysv/namei.c | inode->i_op = &sysv_dir_inode_operations; |
inode | 327 | fs/sysv/namei.c | inode->i_size = 2 * SYSV_DIRSIZE; |
inode | 328 | fs/sysv/namei.c | dir_block = sysv_file_bread(inode,0,1); |
inode | 331 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 332 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 333 | fs/sysv/namei.c | iput(inode); |
inode | 337 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 340 | fs/sysv/namei.c | de->inode = dir->i_ino; |
inode | 342 | fs/sysv/namei.c | inode->i_nlink = 2; |
inode | 345 | fs/sysv/namei.c | inode->i_mode = S_IFDIR | (mode & 0777 & ~current->fs->umask); |
inode | 347 | fs/sysv/namei.c | inode->i_mode |= S_ISGID; |
inode | 348 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 352 | fs/sysv/namei.c | inode->i_nlink=0; |
inode | 353 | fs/sysv/namei.c | iput(inode); |
inode | 356 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 361 | fs/sysv/namei.c | iput(inode); |
inode | 369 | fs/sysv/namei.c | static int empty_dir(struct inode * inode) |
inode | 376 | fs/sysv/namei.c | if (!inode) |
inode | 381 | fs/sysv/namei.c | if (inode->i_size % SYSV_DIRSIZE) |
inode | 383 | fs/sysv/namei.c | if (inode->i_size < pos) |
inode | 385 | fs/sysv/namei.c | bh = sysv_file_bread(inode,0,0); |
inode | 389 | fs/sysv/namei.c | if (!de->inode || strcmp(de->name,".")) |
inode | 392 | fs/sysv/namei.c | if (!de->inode || strcmp(de->name,"..")) |
inode | 394 | fs/sysv/namei.c | sb = inode->i_sb; |
inode | 395 | fs/sysv/namei.c | while (pos < inode->i_size) { |
inode | 397 | fs/sysv/namei.c | bh = sysv_file_bread(inode,block,0); |
inode | 407 | fs/sysv/namei.c | if (de->inode) { |
inode | 421 | fs/sysv/namei.c | printk("Bad directory on device %04x\n",inode->i_dev); |
inode | 425 | fs/sysv/namei.c | int sysv_rmdir(struct inode * dir, const char * name, int len) |
inode | 428 | fs/sysv/namei.c | struct inode * inode; |
inode | 432 | fs/sysv/namei.c | inode = NULL; |
inode | 438 | fs/sysv/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 441 | fs/sysv/namei.c | current->fsuid != inode->i_uid && |
inode | 444 | fs/sysv/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 446 | fs/sysv/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 448 | fs/sysv/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 452 | fs/sysv/namei.c | if (!empty_dir(inode)) { |
inode | 456 | fs/sysv/namei.c | if (de->inode != inode->i_ino) { |
inode | 460 | fs/sysv/namei.c | if (inode->i_count > 1) { |
inode | 464 | fs/sysv/namei.c | if (inode->i_nlink != 2) |
inode | 465 | fs/sysv/namei.c | printk("empty directory has nlink!=2 (%d)\n",inode->i_nlink); |
inode | 466 | fs/sysv/namei.c | de->inode = 0; |
inode | 468 | fs/sysv/namei.c | inode->i_nlink=0; |
inode | 469 | fs/sysv/namei.c | inode->i_dirt=1; |
inode | 471 | fs/sysv/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 476 | fs/sysv/namei.c | iput(inode); |
inode | 481 | fs/sysv/namei.c | int sysv_unlink(struct inode * dir, const char * name, int len) |
inode | 484 | fs/sysv/namei.c | struct inode * inode; |
inode | 490 | fs/sysv/namei.c | inode = NULL; |
inode | 494 | fs/sysv/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
inode | 497 | fs/sysv/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 499 | fs/sysv/namei.c | if (de->inode != inode->i_ino) { |
inode | 500 | fs/sysv/namei.c | iput(inode); |
inode | 507 | fs/sysv/namei.c | current->fsuid != inode->i_uid && |
inode | 510 | fs/sysv/namei.c | if (de->inode != inode->i_ino) { |
inode | 514 | fs/sysv/namei.c | if (!inode->i_nlink) { |
inode | 516 | fs/sysv/namei.c | inode->i_dev,inode->i_ino,inode->i_nlink); |
inode | 517 | fs/sysv/namei.c | inode->i_nlink=1; |
inode | 519 | fs/sysv/namei.c | de->inode = 0; |
inode | 523 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 524 | fs/sysv/namei.c | inode->i_ctime = dir->i_ctime; |
inode | 525 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 529 | fs/sysv/namei.c | iput(inode); |
inode | 534 | fs/sysv/namei.c | int sysv_symlink(struct inode * dir, const char * name, int len, const char * symname) |
inode | 537 | fs/sysv/namei.c | struct inode * inode; |
inode | 545 | fs/sysv/namei.c | if (!(inode = sysv_new_inode(dir))) { |
inode | 549 | fs/sysv/namei.c | inode->i_mode = S_IFLNK | 0777; |
inode | 550 | fs/sysv/namei.c | inode->i_op = &sysv_symlink_inode_operations; |
inode | 551 | fs/sysv/namei.c | name_block = sysv_file_bread(inode,0,1); |
inode | 554 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 555 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 556 | fs/sysv/namei.c | iput(inode); |
inode | 559 | fs/sysv/namei.c | sb = inode->i_sb; |
inode | 567 | fs/sysv/namei.c | inode->i_size = i; |
inode | 568 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 571 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 572 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 573 | fs/sysv/namei.c | iput(inode); |
inode | 580 | fs/sysv/namei.c | inode->i_nlink--; |
inode | 581 | fs/sysv/namei.c | inode->i_dirt = 1; |
inode | 582 | fs/sysv/namei.c | iput(inode); |
inode | 586 | fs/sysv/namei.c | de->inode = inode->i_ino; |
inode | 590 | fs/sysv/namei.c | iput(inode); |
inode | 594 | fs/sysv/namei.c | int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
inode | 623 | fs/sysv/namei.c | de->inode = oldinode->i_ino; |
inode | 635 | fs/sysv/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 660 | fs/sysv/namei.c | (((struct sysv_dir_entry *) ((buffer) + 1*SYSV_DIRSIZE))->inode) |
inode | 672 | fs/sysv/namei.c | static int do_sysv_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 673 | fs/sysv/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 675 | fs/sysv/namei.c | struct inode * old_inode, * new_inode; |
inode | 696 | fs/sysv/namei.c | old_inode = __iget(old_dir->i_sb, old_de->inode, 0); /* don't cross mnt-points */ |
inode | 706 | fs/sysv/namei.c | new_inode = __iget(new_dir->i_sb, new_de->inode, 0); |
inode | 758 | fs/sysv/namei.c | if (new_inode && (new_de->inode != new_inode->i_ino)) |
inode | 760 | fs/sysv/namei.c | if (new_de->inode && !new_inode) |
inode | 762 | fs/sysv/namei.c | if (old_de->inode != old_inode->i_ino) |
inode | 765 | fs/sysv/namei.c | old_de->inode = 0; |
inode | 766 | fs/sysv/namei.c | new_de->inode = old_inode->i_ino; |
inode | 812 | fs/sysv/namei.c | int sysv_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 813 | fs/sysv/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 27 | fs/sysv/symlink.c | static int sysv_readlink(struct inode *, char *, int); |
inode | 28 | fs/sysv/symlink.c | static int sysv_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 51 | fs/sysv/symlink.c | static int sysv_follow_link(struct inode * dir, struct inode * inode, |
inode | 52 | fs/sysv/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 62 | fs/sysv/symlink.c | if (!inode) { |
inode | 66 | fs/sysv/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 68 | fs/sysv/symlink.c | *res_inode = inode; |
inode | 72 | fs/sysv/symlink.c | iput(inode); |
inode | 76 | fs/sysv/symlink.c | if (!(bh = sysv_file_bread(inode, 0, 0))) { /* is reading 1 block enough ?? */ |
inode | 77 | fs/sysv/symlink.c | iput(inode); |
inode | 81 | fs/sysv/symlink.c | iput(inode); |
inode | 89 | fs/sysv/symlink.c | static int sysv_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 96 | fs/sysv/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 97 | fs/sysv/symlink.c | iput(inode); |
inode | 100 | fs/sysv/symlink.c | if (buflen > inode->i_sb->sv_block_size_1) |
inode | 101 | fs/sysv/symlink.c | buflen = inode->i_sb->sv_block_size_1; |
inode | 102 | fs/sysv/symlink.c | bh = sysv_file_bread(inode, 0, 0); |
inode | 103 | fs/sysv/symlink.c | iput(inode); |
inode | 44 | fs/sysv/truncate.c | static int trunc_direct(struct inode * inode) |
inode | 53 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 55 | 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 | 56 | fs/sysv/truncate.c | p = inode->u.sysv_i.i_data + i; |
inode | 60 | fs/sysv/truncate.c | bh = sv_get_hash_table(sb, inode->i_dev, block); |
inode | 61 | fs/sysv/truncate.c | if ((i << sb->sv_block_size_bits) < inode->i_size) { |
inode | 71 | fs/sysv/truncate.c | inode->i_dirt = 1; |
inode | 78 | fs/sysv/truncate.c | static int trunc_indirect(struct inode * inode, unsigned long offset, unsigned long * p, int convert, unsigned char * dirt) |
inode | 94 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 95 | fs/sysv/truncate.c | indbh = sv_bread(sb, inode->i_dev, indblock); |
inode | 106 | fs/sysv/truncate.c | if (inode->i_size < offset) |
inode | 109 | fs/sysv/truncate.c | i = (inode->i_size - offset + sb->sv_block_size_1) >> sb->sv_block_size_bits; |
inode | 117 | fs/sysv/truncate.c | bh = sv_get_hash_table(sb, inode->i_dev, block); |
inode | 118 | fs/sysv/truncate.c | if ((i << sb->sv_block_size_bits) + offset < inode->i_size) { |
inode | 147 | fs/sysv/truncate.c | static int trunc_dindirect(struct inode * inode, unsigned long offset, unsigned long * p, int convert, unsigned char * dirt) |
inode | 162 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 163 | fs/sysv/truncate.c | indbh = sv_bread(sb, inode->i_dev, indblock); |
inode | 173 | fs/sysv/truncate.c | if (inode->i_size < offset) |
inode | 176 | 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 | 184 | fs/sysv/truncate.c | retry |= trunc_indirect(inode,offset+(i<<sb->sv_ind_per_block_bits),ind,sb->sv_convert,&indbh->b_dirt); |
inode | 201 | fs/sysv/truncate.c | static int trunc_tindirect(struct inode * inode, unsigned long offset, unsigned long * p, int convert, unsigned char * dirt) |
inode | 216 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 217 | fs/sysv/truncate.c | indbh = sv_bread(sb, inode->i_dev, indblock); |
inode | 227 | fs/sysv/truncate.c | if (inode->i_size < offset) |
inode | 230 | 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,&indbh->b_dirt); |
inode | 255 | fs/sysv/truncate.c | static int trunc_all(struct inode * inode) |
inode | 259 | fs/sysv/truncate.c | sb = inode->i_sb; |
inode | 260 | fs/sysv/truncate.c | return trunc_direct(inode) |
inode | 261 | fs/sysv/truncate.c | | trunc_indirect(inode,sb->sv_ind0_size,&inode->u.sysv_i.i_data[10],0,&inode->i_dirt) |
inode | 262 | fs/sysv/truncate.c | | trunc_dindirect(inode,sb->sv_ind1_size,&inode->u.sysv_i.i_data[11],0,&inode->i_dirt) |
inode | 263 | fs/sysv/truncate.c | | trunc_tindirect(inode,sb->sv_ind2_size,&inode->u.sysv_i.i_data[12],0,&inode->i_dirt); |
inode | 267 | fs/sysv/truncate.c | void sysv_truncate(struct inode * inode) |
inode | 277 | fs/sysv/truncate.c | if (S_ISLNK(inode->i_mode)) |
inode | 279 | fs/sysv/truncate.c | else if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode))) |
inode | 281 | fs/sysv/truncate.c | while (trunc_all(inode)) { |
inode | 285 | fs/sysv/truncate.c | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
inode | 286 | fs/sysv/truncate.c | inode->i_dirt = 1; |
inode | 30 | fs/umsdos/dir.c | extern struct inode *pseudo_root; |
inode | 34 | fs/umsdos/dir.c | int UMSDOS_dir_read(struct inode *inode,struct file *filp,char *buf, |
inode | 53 | fs/umsdos/dir.c | struct inode *dir, /* Point to a description of the super block */ |
inode | 124 | fs/umsdos/dir.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,0); |
inode | 155 | fs/umsdos/dir.c | struct inode *inode; |
inode | 162 | fs/umsdos/dir.c | ,info.fake.len,&inode); |
inode | 168 | fs/umsdos/dir.c | struct inode *rinode; |
inode | 169 | fs/umsdos/dir.c | lret = umsdos_hlink2inode (inode,&rinode); |
inode | 170 | fs/umsdos/dir.c | inode = rinode; |
inode | 180 | fs/umsdos/dir.c | if (inode != pseudo_root){ |
inode | 181 | fs/umsdos/dir.c | PRINTK (("Trouve ino %d ",inode->i_ino)); |
inode | 183 | fs/umsdos/dir.c | put_fs_long(inode->i_ino,&dirent->d_ino); |
inode | 195 | fs/umsdos/dir.c | dirent->d_ino = inode->i_ino; |
inode | 203 | fs/umsdos/dir.c | iput (inode); |
inode | 206 | fs/umsdos/dir.c | iput (inode); |
inode | 233 | fs/umsdos/dir.c | struct inode *dir, /* Point to a description of the super block */ |
inode | 251 | fs/umsdos/dir.c | struct inode *dir, |
inode | 252 | fs/umsdos/dir.c | struct inode *inode, |
inode | 285 | fs/umsdos/dir.c | if (inode->i_sb == dir->i_sb && !umsdos_isinit(inode)){ |
inode | 286 | fs/umsdos/dir.c | if (S_ISDIR(inode->i_mode)) umsdos_lockcreate(inode); |
inode | 287 | fs/umsdos/dir.c | if (!umsdos_isinit(inode)){ |
inode | 305 | fs/umsdos/dir.c | if (S_ISREG(entry->mode)) entry->mtime = inode->i_mtime; |
inode | 306 | fs/umsdos/dir.c | inode->i_mode = entry->mode; |
inode | 307 | fs/umsdos/dir.c | inode->i_rdev = entry->rdev; |
inode | 308 | fs/umsdos/dir.c | inode->i_atime = entry->atime; |
inode | 309 | fs/umsdos/dir.c | inode->i_ctime = entry->ctime; |
inode | 310 | fs/umsdos/dir.c | inode->i_mtime = entry->mtime; |
inode | 311 | fs/umsdos/dir.c | inode->i_uid = entry->uid; |
inode | 312 | fs/umsdos/dir.c | inode->i_gid = entry->gid; |
inode | 323 | fs/umsdos/dir.c | inode->i_nlink = entry->nlink; |
inode | 328 | fs/umsdos/dir.c | umsdos_patch_inode(inode,dir,emd_pos); |
inode | 330 | fs/umsdos/dir.c | if (S_ISDIR(inode->i_mode)) umsdos_unlockcreate(inode); |
inode | 331 | fs/umsdos/dir.c | if (inode->u.umsdos_i.i_emd_owner==0) printk ("emd_owner still 0 ???\n"); |
inode | 342 | fs/umsdos/dir.c | struct inode *dir, |
inode | 343 | fs/umsdos/dir.c | struct inode *inode, |
inode | 347 | fs/umsdos/dir.c | if (inode == pseudo_root){ |
inode | 356 | fs/umsdos/dir.c | struct inode *emddir = umsdos_emd_dir_lookup(dir,0); |
inode | 367 | fs/umsdos/dir.c | ,inode->i_ino); |
inode | 368 | fs/umsdos/dir.c | }else if (dirent.d_ino == inode->i_ino){ |
inode | 373 | fs/umsdos/dir.c | inode->u.umsdos_i.i_dir_owner = dir->i_ino; |
inode | 374 | fs/umsdos/dir.c | inode->u.umsdos_i.i_emd_owner = 0; |
inode | 375 | fs/umsdos/dir.c | umsdos_setup_dir_inode(inode); |
inode | 390 | fs/umsdos/dir.c | ,inode->i_ino); |
inode | 392 | fs/umsdos/dir.c | }else if (dirent.d_ino == inode->i_ino){ |
inode | 394 | fs/umsdos/dir.c | umsdos_lookup_patch (dir,inode,entry,f_pos); |
inode | 407 | fs/umsdos/dir.c | struct inode *dir, |
inode | 408 | fs/umsdos/dir.c | struct inode **result, |
inode | 416 | fs/umsdos/dir.c | struct inode *adir = *result; |
inode | 429 | fs/umsdos/dir.c | struct inode *inode, |
inode | 433 | fs/umsdos/dir.c | struct inode *dir = inode; |
inode | 441 | fs/umsdos/dir.c | PRINTK (("locate_path mode %x ",inode->i_mode)); |
inode | 442 | fs/umsdos/dir.c | if (!S_ISDIR(inode->i_mode)){ |
inode | 443 | fs/umsdos/dir.c | ret = umsdos_get_dirowner (inode,&dir); |
inode | 446 | fs/umsdos/dir.c | ret = umsdos_inode2entry (dir,inode,&entry); |
inode | 458 | fs/umsdos/dir.c | struct inode *adir; |
inode | 486 | fs/umsdos/dir.c | struct inode *dir, |
inode | 506 | fs/umsdos/dir.c | struct inode *dir, |
inode | 509 | fs/umsdos/dir.c | struct inode **result, /* Will hold inode of the file, if successful */ |
inode | 545 | fs/umsdos/dir.c | struct inode *aadir; |
inode | 575 | fs/umsdos/dir.c | struct inode *inode; |
inode | 577 | fs/umsdos/dir.c | inode = *result; |
inode | 578 | fs/umsdos/dir.c | if (inode == NULL){ |
inode | 583 | fs/umsdos/dir.c | umsdos_lookup_patch (dir,inode,&info.entry,info.f_pos); |
inode | 584 | fs/umsdos/dir.c | PRINTK (("lookup ino %d flags %d\n",inode->i_ino |
inode | 587 | fs/umsdos/dir.c | ret = umsdos_hlink2inode (inode,result); |
inode | 615 | fs/umsdos/dir.c | struct inode *dir, |
inode | 618 | fs/umsdos/dir.c | struct inode **result) /* Will hold inode of the file, if successful */ |
inode | 626 | fs/umsdos/dir.c | int umsdos_hlink2inode (struct inode *hlink, struct inode **result) |
inode | 641 | fs/umsdos/dir.c | struct inode *dir; |
inode | 26 | fs/umsdos/emd.c | struct inode *inode, |
inode | 34 | fs/umsdos/emd.c | ret = msdos_readdir(inode,filp,dirent,count); |
inode | 42 | fs/umsdos/emd.c | struct inode *inode, |
inode | 50 | fs/umsdos/emd.c | ret = msdos_file_read(inode,filp,buf,count); |
inode | 58 | fs/umsdos/emd.c | struct inode *inode, |
inode | 66 | fs/umsdos/emd.c | ret = msdos_file_write(inode,filp,buf,count); |
inode | 79 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 95 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 116 | fs/umsdos/emd.c | struct inode *umsdos_emd_dir_lookup(struct inode *dir, int creat) |
inode | 118 | fs/umsdos/emd.c | struct inode *ret = NULL; |
inode | 156 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 177 | fs/umsdos/emd.c | struct inode *dir, |
inode | 178 | fs/umsdos/emd.c | struct inode *emd_dir, |
inode | 233 | fs/umsdos/emd.c | struct inode *inode, |
inode | 245 | fs/umsdos/emd.c | remain = inode->i_size - buf->filp.f_pos; |
inode | 248 | fs/umsdos/emd.c | ret = umsdos_emd_dir_read (inode,&buf->filp,buf->buffer+mustmove |
inode | 280 | fs/umsdos/emd.c | struct inode *dir, |
inode | 283 | fs/umsdos/emd.c | struct inode **pt_emd_dir) /* Will hold the emd_dir inode */ |
inode | 292 | fs/umsdos/emd.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,1); |
inode | 380 | fs/umsdos/emd.c | struct inode *dir, |
inode | 383 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 399 | fs/umsdos/emd.c | struct inode *dir, |
inode | 402 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 427 | fs/umsdos/emd.c | struct inode *dir, |
inode | 431 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 457 | fs/umsdos/emd.c | int umsdos_isempty (struct inode *dir) |
inode | 460 | fs/umsdos/emd.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,0); |
inode | 489 | fs/umsdos/emd.c | struct inode *dir, |
inode | 495 | fs/umsdos/emd.c | struct inode *emd_dir; |
inode | 33 | fs/umsdos/file.c | struct inode *inode, |
inode | 39 | fs/umsdos/file.c | int ret = msdos_file_read(inode,filp,buf,count); |
inode | 40 | fs/umsdos/file.c | if (!IS_RDONLY(inode)){ |
inode | 41 | fs/umsdos/file.c | inode->i_atime = CURRENT_TIME; |
inode | 42 | fs/umsdos/file.c | inode->i_dirt = 1; |
inode | 50 | fs/umsdos/file.c | struct inode *inode, |
inode | 55 | fs/umsdos/file.c | return msdos_file_write(inode,filp,buf,count); |
inode | 60 | fs/umsdos/file.c | static void UMSDOS_truncate(struct inode *inode) |
inode | 63 | fs/umsdos/file.c | msdos_truncate (inode); |
inode | 64 | fs/umsdos/file.c | inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 65 | fs/umsdos/file.c | inode->i_dirt = 1; |
inode | 27 | fs/umsdos/inode.c | struct inode *pseudo_root=NULL; /* Useful to simulate the pseudo DOS */ |
inode | 45 | fs/umsdos/inode.c | void UMSDOS_put_inode(struct inode *inode) |
inode | 47 | fs/umsdos/inode.c | PRINTK (("put inode %x owner %x pos %d dir %x\n",inode |
inode | 48 | fs/umsdos/inode.c | ,inode->u.umsdos_i.i_emd_owner,inode->u.umsdos_i.pos |
inode | 49 | fs/umsdos/inode.c | ,inode->u.umsdos_i.i_emd_dir)); |
inode | 50 | fs/umsdos/inode.c | if (inode != NULL && inode == pseudo_root){ |
inode | 53 | fs/umsdos/inode.c | msdos_put_inode(inode); |
inode | 75 | fs/umsdos/inode.c | struct inode *dir, |
inode | 78 | fs/umsdos/inode.c | struct inode **result) /* Will hold inode of the file, if successful */ |
inode | 91 | fs/umsdos/inode.c | void umsdos_setup_dir_inode (struct inode *inode) |
inode | 93 | fs/umsdos/inode.c | inode->u.umsdos_i.i_emd_dir = 0; |
inode | 95 | fs/umsdos/inode.c | struct inode *emd_dir = umsdos_emd_dir_lookup (inode,0); |
inode | 97 | fs/umsdos/inode.c | inode->i_op = emd_dir != NULL |
inode | 107 | fs/umsdos/inode.c | struct inode *inode, |
inode | 108 | fs/umsdos/inode.c | struct inode *dir, |
inode | 111 | fs/umsdos/inode.c | struct inode *emd_owner = umsdos_emd_dir_lookup(dir,1); |
inode | 112 | fs/umsdos/inode.c | inode->u.umsdos_i.i_dir_owner = dir->i_ino; |
inode | 113 | fs/umsdos/inode.c | inode->u.umsdos_i.i_emd_owner = emd_owner->i_ino; |
inode | 115 | fs/umsdos/inode.c | inode->u.umsdos_i.pos = f_pos; |
inode | 121 | fs/umsdos/inode.c | int umsdos_isinit (struct inode *inode) |
inode | 124 | fs/umsdos/inode.c | return inode->u.umsdos_i.i_emd_owner != 0; |
inode | 126 | fs/umsdos/inode.c | return inode->i_atime != 0; |
inode | 128 | fs/umsdos/inode.c | return inode->i_count > 1; |
inode | 135 | fs/umsdos/inode.c | struct inode *inode, |
inode | 136 | fs/umsdos/inode.c | struct inode *dir, /* May be NULL */ |
inode | 155 | fs/umsdos/inode.c | if (!umsdos_isinit(inode)){ |
inode | 156 | fs/umsdos/inode.c | inode->u.umsdos_i.i_emd_dir = 0; |
inode | 157 | fs/umsdos/inode.c | if (S_ISREG(inode->i_mode)){ |
inode | 158 | fs/umsdos/inode.c | if (inode->i_op->bmap != NULL){ |
inode | 159 | fs/umsdos/inode.c | inode->i_op = &umsdos_file_inode_operations; |
inode | 161 | fs/umsdos/inode.c | inode->i_op = &umsdos_file_inode_operations_no_bmap; |
inode | 163 | fs/umsdos/inode.c | }else if (S_ISDIR(inode->i_mode)){ |
inode | 165 | fs/umsdos/inode.c | umsdos_setup_dir_inode(inode); |
inode | 167 | fs/umsdos/inode.c | }else if (S_ISLNK(inode->i_mode)){ |
inode | 168 | fs/umsdos/inode.c | inode->i_op = &umsdos_symlink_inode_operations; |
inode | 169 | fs/umsdos/inode.c | }else if (S_ISCHR(inode->i_mode)){ |
inode | 170 | fs/umsdos/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 171 | fs/umsdos/inode.c | }else if (S_ISBLK(inode->i_mode)){ |
inode | 172 | fs/umsdos/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 173 | fs/umsdos/inode.c | }else if (S_ISFIFO(inode->i_mode)){ |
inode | 174 | fs/umsdos/inode.c | init_fifo(inode); |
inode | 187 | fs/umsdos/inode.c | umsdos_set_dirinfo (inode,dir,f_pos); |
inode | 194 | fs/umsdos/inode.c | struct inode *emd_owner = umsdos_emd_dir_lookup(dir,1); |
inode | 196 | fs/umsdos/inode.c | if (emd_owner->i_ino != inode->u.umsdos_i.i_emd_owner){ |
inode | 198 | fs/umsdos/inode.c | ,inode->i_ino,emd_owner->i_ino,inode->u.umsdos_i.i_emd_owner); |
inode | 207 | fs/umsdos/inode.c | struct inode *inode, |
inode | 208 | fs/umsdos/inode.c | struct inode **result) /* Hold NULL if any error */ |
inode | 212 | fs/umsdos/inode.c | unsigned long ino = inode->u.umsdos_i.i_dir_owner; |
inode | 217 | fs/umsdos/inode.c | struct inode *dir = *result = iget(inode->i_sb,ino); |
inode | 228 | fs/umsdos/inode.c | void UMSDOS_read_inode(struct inode *inode) |
inode | 230 | fs/umsdos/inode.c | PRINTK (("read inode %x ino = %d ",inode,inode->i_ino)); |
inode | 231 | fs/umsdos/inode.c | msdos_read_inode(inode); |
inode | 232 | fs/umsdos/inode.c | PRINTK (("ino = %d %d\n",inode->i_ino,inode->i_count)); |
inode | 233 | fs/umsdos/inode.c | if (S_ISDIR(inode->i_mode) |
inode | 234 | fs/umsdos/inode.c | && (inode->u.umsdos_i.u.dir_info.creating != 0 |
inode | 235 | fs/umsdos/inode.c | || inode->u.umsdos_i.u.dir_info.looking != 0 |
inode | 236 | fs/umsdos/inode.c | || inode->u.umsdos_i.u.dir_info.p != NULL)){ |
inode | 238 | fs/umsdos/inode.c | ,inode->u.umsdos_i.u.dir_info.creating |
inode | 239 | fs/umsdos/inode.c | ,inode->u.umsdos_i.u.dir_info.looking |
inode | 240 | fs/umsdos/inode.c | ,inode->u.umsdos_i.u.dir_info.p)); |
inode | 255 | fs/umsdos/inode.c | umsdos_patch_inode(inode,NULL,0); |
inode | 261 | fs/umsdos/inode.c | void UMSDOS_write_inode(struct inode *inode) |
inode | 265 | fs/umsdos/inode.c | PRINTK (("UMSDOS_write_inode emd %d\n",inode->u.umsdos_i.i_emd_owner)); |
inode | 266 | fs/umsdos/inode.c | msdos_write_inode(inode); |
inode | 267 | fs/umsdos/inode.c | newattrs.ia_mtime = inode->i_mtime; |
inode | 268 | fs/umsdos/inode.c | newattrs.ia_atime = inode->i_atime; |
inode | 269 | fs/umsdos/inode.c | newattrs.ia_ctime = inode->i_ctime; |
inode | 276 | fs/umsdos/inode.c | UMSDOS_notify_change (inode, &newattrs); |
inode | 277 | fs/umsdos/inode.c | inode->i_dirt = 0; |
inode | 280 | fs/umsdos/inode.c | int UMSDOS_notify_change(struct inode *inode, struct iattr *attr) |
inode | 284 | fs/umsdos/inode.c | if ((ret = inode_change_ok(inode, attr)) != 0) |
inode | 287 | fs/umsdos/inode.c | if (inode->i_nlink > 0){ |
inode | 293 | fs/umsdos/inode.c | unsigned long i_emd_owner = inode->u.umsdos_i.i_emd_owner; |
inode | 294 | fs/umsdos/inode.c | if (inode == inode->i_sb->s_mounted){ |
inode | 314 | fs/umsdos/inode.c | struct inode *emd_owner = iget (inode->i_sb,i_emd_owner); |
inode | 315 | fs/umsdos/inode.c | PRINTK (("notify change %p ",inode)); |
inode | 322 | fs/umsdos/inode.c | filp.f_pos = inode->u.umsdos_i.pos; |
inode | 343 | fs/umsdos/inode.c | entry.nlink = inode->i_nlink; |
inode | 344 | fs/umsdos/inode.c | filp.f_pos = inode->u.umsdos_i.pos; |
inode | 349 | fs/umsdos/inode.c | ,inode->u.umsdos_i.pos |
inode | 362 | fs/umsdos/inode.c | inode_setattr(inode, attr); |
inode | 449 | fs/umsdos/inode.c | struct inode *pseudo; |
inode | 454 | fs/umsdos/inode.c | struct inode *etc = NULL; |
inode | 455 | fs/umsdos/inode.c | struct inode *rc = NULL; |
inode | 459 | fs/umsdos/inode.c | struct inode *init; |
inode | 27 | fs/umsdos/ioctl.c | struct inode *dir, |
inode | 96 | fs/umsdos/ioctl.c | struct inode *emd_dir = umsdos_emd_dir_lookup (dir,0); |
inode | 140 | fs/umsdos/ioctl.c | struct inode *emd_dir = umsdos_emd_dir_lookup (dir,1); |
inode | 233 | fs/umsdos/ioctl.c | struct inode *inode; |
inode | 235 | fs/umsdos/ioctl.c | ,data.dos_dirent.d_reclen,&inode); |
inode | 237 | fs/umsdos/ioctl.c | data.stat.st_ino = inode->i_ino; |
inode | 238 | fs/umsdos/ioctl.c | data.stat.st_mode = inode->i_mode; |
inode | 239 | fs/umsdos/ioctl.c | data.stat.st_size = inode->i_size; |
inode | 240 | fs/umsdos/ioctl.c | data.stat.st_atime = inode->i_atime; |
inode | 241 | fs/umsdos/ioctl.c | data.stat.st_ctime = inode->i_ctime; |
inode | 242 | fs/umsdos/ioctl.c | data.stat.st_mtime = inode->i_mtime; |
inode | 244 | fs/umsdos/ioctl.c | iput (inode); |
inode | 35 | fs/umsdos/namei.c | static int umsdos_waitcreate(struct inode *dir) |
inode | 48 | fs/umsdos/namei.c | static void umsdos_waitlookup (struct inode *dir) |
inode | 57 | fs/umsdos/namei.c | void umsdos_lockcreate (struct inode *dir) |
inode | 99 | fs/umsdos/namei.c | static void umsdos_lockcreate2 (struct inode *dir1, struct inode *dir2) |
inode | 124 | fs/umsdos/namei.c | void umsdos_startlookup (struct inode *dir) |
inode | 134 | fs/umsdos/namei.c | void umsdos_unlockcreate (struct inode *dir) |
inode | 146 | fs/umsdos/namei.c | void umsdos_endlookup (struct inode *dir) |
inode | 156 | fs/umsdos/namei.c | static void umsdos_lockcreate (struct inode *dir){} |
inode | 157 | fs/umsdos/namei.c | static void umsdos_lockcreate2 (struct inode *dir1, struct inode *dir2){} |
inode | 158 | fs/umsdos/namei.c | void umsdos_startlookup (struct inode *dir){} |
inode | 159 | fs/umsdos/namei.c | static void umsdos_unlockcreate (struct inode *dir){} |
inode | 160 | fs/umsdos/namei.c | void umsdos_endlookup (struct inode *dir){} |
inode | 163 | fs/umsdos/namei.c | struct inode *dir, |
inode | 204 | fs/umsdos/namei.c | struct inode *dir, |
inode | 211 | fs/umsdos/namei.c | struct inode **result) /* Will hold the inode of the newly created */ |
inode | 236 | fs/umsdos/namei.c | struct inode *inode = *result; |
inode | 237 | fs/umsdos/namei.c | umsdos_lookup_patch (dir,inode,&info.entry,info.f_pos); |
inode | 238 | fs/umsdos/namei.c | PRINTK (("inode %p[%d] ",inode,inode->i_count)); |
inode | 313 | fs/umsdos/namei.c | struct inode * old_dir, |
inode | 316 | fs/umsdos/namei.c | struct inode * new_dir, |
inode | 380 | fs/umsdos/namei.c | struct inode *inode; |
inode | 384 | fs/umsdos/namei.c | ,&inode); |
inode | 394 | fs/umsdos/namei.c | umsdos_set_dirinfo (inode,new_dir,new_info.f_pos); |
inode | 396 | fs/umsdos/namei.c | iput (inode); |
inode | 425 | fs/umsdos/namei.c | struct inode * dir, |
inode | 442 | fs/umsdos/namei.c | struct inode *inode; |
inode | 446 | fs/umsdos/namei.c | ret = umsdos_create_any (dir,name,len,mode,0,flags,&inode); |
inode | 453 | fs/umsdos/namei.c | ret = umsdos_file_write_kmem (inode,&filp,(char*)symname,len); |
inode | 454 | fs/umsdos/namei.c | iput (inode); |
inode | 478 | fs/umsdos/namei.c | struct inode * dir, |
inode | 489 | fs/umsdos/namei.c | struct inode * oldinode, |
inode | 490 | fs/umsdos/namei.c | struct inode * dir, |
inode | 572 | fs/umsdos/namei.c | struct inode *olddir; |
inode | 669 | fs/umsdos/namei.c | struct inode *dir, |
inode | 673 | fs/umsdos/namei.c | struct inode **result) /* Will hold the inode of the newly created */ |
inode | 682 | fs/umsdos/namei.c | struct inode * dir, |
inode | 721 | fs/umsdos/namei.c | struct inode *subdir; |
inode | 725 | fs/umsdos/namei.c | struct inode *result; |
inode | 748 | fs/umsdos/namei.c | struct inode * dir, |
inode | 768 | fs/umsdos/namei.c | struct inode *inode; |
inode | 769 | fs/umsdos/namei.c | int ret = umsdos_create_any (dir,name,len,mode,rdev,0,&inode); |
inode | 770 | fs/umsdos/namei.c | iput (inode); |
inode | 778 | fs/umsdos/namei.c | struct inode * dir, |
inode | 871 | fs/umsdos/namei.c | struct inode *sdir; |
inode | 932 | fs/umsdos/namei.c | struct inode * dir, |
inode | 962 | fs/umsdos/namei.c | struct inode *inode; |
inode | 964 | fs/umsdos/namei.c | ret = UMSDOS_lookup (dir,name,len,&inode); |
inode | 966 | fs/umsdos/namei.c | PRINTK (("unlink nlink = %d ",inode->i_nlink)); |
inode | 967 | fs/umsdos/namei.c | inode->i_nlink--; |
inode | 968 | fs/umsdos/namei.c | if (inode->i_nlink == 0){ |
inode | 969 | fs/umsdos/namei.c | struct inode *hdir = iget(inode->i_sb |
inode | 970 | fs/umsdos/namei.c | ,inode->u.umsdos_i.i_dir_owner); |
inode | 972 | fs/umsdos/namei.c | ret = umsdos_inode2entry (hdir,inode,&entry); |
inode | 982 | fs/umsdos/namei.c | ret = UMSDOS_notify_change (inode, &newattrs); |
inode | 984 | fs/umsdos/namei.c | iput (inode); |
inode | 1016 | fs/umsdos/namei.c | struct inode * old_dir, |
inode | 1019 | fs/umsdos/namei.c | struct inode * new_dir, |
inode | 29 | fs/umsdos/rdir.c | extern struct inode *pseudo_root; |
inode | 32 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 70 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 73 | fs/umsdos/rdir.c | struct inode **result) /* Will hold inode of the file, if successful */ |
inode | 92 | fs/umsdos/rdir.c | struct inode *inode = *result; |
inode | 93 | fs/umsdos/rdir.c | if (inode == pseudo_root){ |
inode | 101 | fs/umsdos/rdir.c | }else if (S_ISDIR(inode->i_mode)){ |
inode | 104 | fs/umsdos/rdir.c | umsdos_setup_dir_inode(inode); |
inode | 113 | fs/umsdos/rdir.c | struct inode *dir, |
inode | 147 | fs/umsdos/rdir.c | struct inode *sdir; |
inode | 32 | fs/umsdos/symlink.c | struct inode *inode, |
inode | 34 | fs/umsdos/symlink.c | int (*msdos_read)(struct inode *, struct file *, char *, int), |
inode | 37 | fs/umsdos/symlink.c | int ret = inode->i_size; |
inode | 42 | fs/umsdos/symlink.c | if ((*msdos_read) (inode, &filp, buffer,ret) != ret){ |
inode | 54 | fs/umsdos/symlink.c | struct inode * dir, |
inode | 55 | fs/umsdos/symlink.c | struct inode * inode, |
inode | 58 | fs/umsdos/symlink.c | struct inode ** res_inode) |
inode | 71 | fs/umsdos/symlink.c | if (!inode){ |
inode | 74 | fs/umsdos/symlink.c | }else if (!S_ISLNK(inode->i_mode)){ |
inode | 76 | fs/umsdos/symlink.c | *res_inode = inode; |
inode | 77 | fs/umsdos/symlink.c | inode = NULL; |
inode | 80 | fs/umsdos/symlink.c | ret = umsdos_readlink_x (inode,path |
inode | 85 | fs/umsdos/symlink.c | iput(inode); |
inode | 86 | fs/umsdos/symlink.c | inode = NULL; |
inode | 98 | fs/umsdos/symlink.c | iput(inode); |
inode | 104 | fs/umsdos/symlink.c | static int UMSDOS_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 107 | fs/umsdos/symlink.c | if (S_ISLNK(inode->i_mode)) { |
inode | 108 | fs/umsdos/symlink.c | ret = umsdos_readlink_x (inode,buffer,msdos_file_read,buflen); |
inode | 110 | fs/umsdos/symlink.c | PRINTK (("readlink %d %x bufsiz %d\n",ret,inode->i_mode,buflen)); |
inode | 111 | fs/umsdos/symlink.c | iput(inode); |
inode | 282 | fs/xiafs/bitmap.c | void xiafs_free_inode(struct inode * inode) |
inode | 288 | fs/xiafs/bitmap.c | if (!inode) |
inode | 290 | fs/xiafs/bitmap.c | if (!inode->i_dev || inode->i_count!=1 || inode->i_nlink || !inode->i_sb || |
inode | 291 | fs/xiafs/bitmap.c | inode->i_ino < 3 || inode->i_ino > inode->i_sb->u.xiafs_sb.s_ninodes) { |
inode | 295 | fs/xiafs/bitmap.c | sb = inode->i_sb; |
inode | 296 | fs/xiafs/bitmap.c | ino = inode->i_ino; |
inode | 300 | fs/xiafs/bitmap.c | clear_inode(inode); |
inode | 304 | fs/xiafs/bitmap.c | inode->i_dev, ino, ino, WHERE_ERR); |
inode | 309 | fs/xiafs/bitmap.c | struct inode * xiafs_new_inode(struct inode * dir) |
inode | 312 | fs/xiafs/bitmap.c | struct inode * inode; |
inode | 316 | fs/xiafs/bitmap.c | if (!dir || !(inode = get_empty_inode())) |
inode | 318 | fs/xiafs/bitmap.c | inode->i_sb = sb; |
inode | 319 | fs/xiafs/bitmap.c | inode->i_flags = inode->i_sb->s_flags; |
inode | 323 | fs/xiafs/bitmap.c | iput(inode); |
inode | 326 | fs/xiafs/bitmap.c | inode->i_count = 1; |
inode | 327 | fs/xiafs/bitmap.c | inode->i_nlink = 1; |
inode | 328 | fs/xiafs/bitmap.c | inode->i_dev = sb->s_dev; |
inode | 329 | fs/xiafs/bitmap.c | inode->i_uid = current->fsuid; |
inode | 330 | fs/xiafs/bitmap.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
inode | 331 | fs/xiafs/bitmap.c | inode->i_dirt = 1; |
inode | 332 | fs/xiafs/bitmap.c | inode->i_ino = tmp; |
inode | 333 | fs/xiafs/bitmap.c | inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME; |
inode | 334 | fs/xiafs/bitmap.c | inode->i_op = NULL; |
inode | 335 | fs/xiafs/bitmap.c | inode->i_blocks = 0; |
inode | 336 | fs/xiafs/bitmap.c | inode->i_blksize = XIAFS_ZSIZE(inode->i_sb); |
inode | 337 | fs/xiafs/bitmap.c | insert_inode_hash(inode); |
inode | 338 | fs/xiafs/bitmap.c | return inode; |
inode | 29 | fs/xiafs/dir.c | static int xiafs_dir_read(struct inode *, struct file *, char *, int); |
inode | 30 | fs/xiafs/dir.c | static int xiafs_readdir(struct inode *, struct file *, struct dirent *, int); |
inode | 66 | fs/xiafs/dir.c | static int xiafs_dir_read(struct inode * inode, |
inode | 72 | fs/xiafs/dir.c | static int xiafs_readdir(struct inode * inode, |
inode | 79 | fs/xiafs/dir.c | if (!inode || !inode->i_sb || !S_ISDIR(inode->i_mode)) |
inode | 81 | fs/xiafs/dir.c | if (inode->i_size & (XIAFS_ZSIZE(inode->i_sb) - 1) ) |
inode | 84 | fs/xiafs/dir.c | while (!ret && filp->f_pos < inode->i_size) { |
inode | 85 | fs/xiafs/dir.c | offset = filp->f_pos & (XIAFS_ZSIZE(inode->i_sb) - 1); |
inode | 86 | fs/xiafs/dir.c | bh = xiafs_bread(inode, filp->f_pos >> XIAFS_ZSIZE_BITS(inode->i_sb),0); |
inode | 88 | fs/xiafs/dir.c | filp->f_pos += XIAFS_ZSIZE(inode->i_sb)-offset; |
inode | 91 | fs/xiafs/dir.c | for (i = 0; i < XIAFS_ZSIZE(inode->i_sb) && i < offset; ) { |
inode | 100 | fs/xiafs/dir.c | while (!ret && offset < XIAFS_ZSIZE(inode->i_sb) && filp->f_pos < inode->i_size) { |
inode | 101 | fs/xiafs/dir.c | if (de->d_ino > inode->i_sb->u.xiafs_sb.s_ninodes || |
inode | 103 | fs/xiafs/dir.c | (char *)de+de->d_rec_len > XIAFS_ZSIZE(inode->i_sb)+bh->b_data || |
inode | 119 | fs/xiafs/dir.c | if (!IS_RDONLY (inode)) { |
inode | 120 | fs/xiafs/dir.c | inode->i_atime=CURRENT_TIME; |
inode | 121 | fs/xiafs/dir.c | inode->i_dirt=1; |
inode | 129 | fs/xiafs/dir.c | if (offset > XIAFS_ZSIZE(inode->i_sb)) { |
inode | 134 | fs/xiafs/dir.c | if (!IS_RDONLY (inode)) { |
inode | 135 | fs/xiafs/dir.c | inode->i_atime=CURRENT_TIME; |
inode | 136 | fs/xiafs/dir.c | inode->i_dirt=1; |
inode | 35 | fs/xiafs/file.c | static int xiafs_file_read(struct inode *, struct file *, char *, int); |
inode | 36 | fs/xiafs/file.c | static int xiafs_file_write(struct inode *, struct file *, char *, int); |
inode | 74 | fs/xiafs/file.c | xiafs_file_read(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 83 | fs/xiafs/file.c | if (!inode) { |
inode | 87 | fs/xiafs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 92 | fs/xiafs/file.c | left = inode->i_size - offset; |
inode | 98 | fs/xiafs/file.c | zone_nr = offset >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 99 | fs/xiafs/file.c | offset &= XIAFS_ZSIZE(inode->i_sb) -1 ; |
inode | 100 | fs/xiafs/file.c | f_zones =(inode->i_size+XIAFS_ZSIZE(inode->i_sb)-1)>>XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 101 | fs/xiafs/file.c | zones = (left+offset+XIAFS_ZSIZE(inode->i_sb)-1) >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 104 | fs/xiafs/file.c | if(zones < read_ahead[MAJOR(inode->i_dev)] >> (1+XIAFS_ZSHIFT(inode->i_sb))) |
inode | 105 | fs/xiafs/file.c | zones = read_ahead[MAJOR(inode->i_dev)] >> (1+XIAFS_ZSHIFT(inode->i_sb)); |
inode | 124 | fs/xiafs/file.c | *bhb = xiafs_getblk(inode, zone_nr++, 0); |
inode | 156 | fs/xiafs/file.c | if (left < XIAFS_ZSIZE(inode->i_sb) - offset) |
inode | 159 | fs/xiafs/file.c | chars = XIAFS_ZSIZE(inode->i_sb) - offset; |
inode | 186 | fs/xiafs/file.c | if (!IS_RDONLY (inode)) { |
inode | 187 | fs/xiafs/file.c | inode->i_atime = CURRENT_TIME; |
inode | 188 | fs/xiafs/file.c | inode->i_dirt = 1; |
inode | 194 | fs/xiafs/file.c | xiafs_file_write(struct inode * inode, struct file * filp, char * buf, int count) |
inode | 201 | fs/xiafs/file.c | if (!inode) { |
inode | 205 | fs/xiafs/file.c | if (!S_ISREG(inode->i_mode)) { |
inode | 214 | fs/xiafs/file.c | pos = inode->i_size; |
inode | 219 | fs/xiafs/file.c | bh = xiafs_getblk(inode, pos >> XIAFS_ZSIZE_BITS(inode->i_sb), 1); |
inode | 225 | fs/xiafs/file.c | c = XIAFS_ZSIZE(inode->i_sb) - (pos & (XIAFS_ZSIZE(inode->i_sb) - 1)); |
inode | 228 | fs/xiafs/file.c | if (c != XIAFS_ZSIZE(inode->i_sb) && !bh->b_uptodate) { |
inode | 238 | fs/xiafs/file.c | cp = (pos & (XIAFS_ZSIZE(inode->i_sb)-1)) + bh->b_data; |
inode | 240 | fs/xiafs/file.c | if (pos > inode->i_size) { |
inode | 241 | fs/xiafs/file.c | inode->i_size = pos; |
inode | 242 | 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 | 30 | fs/xiafs/fsync.c | #define blocksize (XIAFS_ZSIZE(inode->i_sb)) |
inode | 31 | fs/xiafs/fsync.c | #define addr_per_block (XIAFS_ADDRS_PER_Z(inode->i_sb)) |
inode | 33 | fs/xiafs/fsync.c | static int sync_block (struct inode * inode, unsigned long * block, int wait) |
inode | 41 | fs/xiafs/fsync.c | bh = get_hash_table(inode->i_dev, *block, blocksize); |
inode | 62 | fs/xiafs/fsync.c | static int sync_iblock (struct inode * inode, unsigned long * iblock, |
inode | 71 | fs/xiafs/fsync.c | rc = sync_block (inode, iblock, wait); |
inode | 74 | fs/xiafs/fsync.c | *bh = bread(inode->i_dev, tmp, blocksize); |
inode | 86 | fs/xiafs/fsync.c | static int sync_direct(struct inode *inode, int wait) |
inode | 92 | fs/xiafs/fsync.c | rc = sync_block (inode, inode->u.ext_i.i_data + i, wait); |
inode | 101 | fs/xiafs/fsync.c | static int sync_indirect(struct inode *inode, unsigned long *iblock, int wait) |
inode | 107 | fs/xiafs/fsync.c | rc = sync_iblock (inode, iblock, &ind_bh, wait); |
inode | 112 | fs/xiafs/fsync.c | rc = sync_block (inode, |
inode | 124 | fs/xiafs/fsync.c | static int sync_dindirect(struct inode *inode, unsigned long *diblock, |
inode | 131 | fs/xiafs/fsync.c | rc = sync_iblock (inode, diblock, &dind_bh, wait); |
inode | 136 | fs/xiafs/fsync.c | rc = sync_indirect (inode, |
inode | 148 | fs/xiafs/fsync.c | int xiafs_sync_file(struct inode * inode, struct file * file) |
inode | 152 | fs/xiafs/fsync.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 153 | fs/xiafs/fsync.c | S_ISLNK(inode->i_mode))) |
inode | 157 | fs/xiafs/fsync.c | err |= sync_direct(inode, wait); |
inode | 158 | fs/xiafs/fsync.c | err |= sync_indirect(inode, &inode->u.xiafs_i.i_ind_zone, wait); |
inode | 159 | fs/xiafs/fsync.c | err |= sync_dindirect(inode, &inode->u.xiafs_i.i_dind_zone, wait); |
inode | 161 | fs/xiafs/fsync.c | err |= xiafs_sync_inode (inode); |
inode | 34 | fs/xiafs/inode.c | void xiafs_put_inode(struct inode *inode) |
inode | 36 | fs/xiafs/inode.c | if (inode->i_nlink) |
inode | 38 | fs/xiafs/inode.c | inode->i_size = 0; |
inode | 39 | fs/xiafs/inode.c | xiafs_truncate(inode); |
inode | 40 | fs/xiafs/inode.c | xiafs_free_inode(inode); |
inode | 201 | fs/xiafs/inode.c | int xiafs_bmap(struct inode * inode,int zone) |
inode | 209 | fs/xiafs/inode.c | if (zone >= 8+(1+XIAFS_ADDRS_PER_Z(inode->i_sb))*XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 213 | fs/xiafs/inode.c | if (!IS_RDONLY (inode)) { |
inode | 214 | fs/xiafs/inode.c | inode->i_atime = CURRENT_TIME; |
inode | 215 | fs/xiafs/inode.c | inode->i_dirt = 1; |
inode | 218 | fs/xiafs/inode.c | return inode->u.xiafs_i.i_zone[zone]; |
inode | 220 | fs/xiafs/inode.c | if (zone < XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 221 | fs/xiafs/inode.c | i = inode->u.xiafs_i.i_ind_zone; |
inode | 223 | fs/xiafs/inode.c | i = zone_bmap(bread(inode->i_dev, i, XIAFS_ZSIZE(inode->i_sb)), zone); |
inode | 226 | fs/xiafs/inode.c | zone -= XIAFS_ADDRS_PER_Z(inode->i_sb); |
inode | 227 | fs/xiafs/inode.c | i = inode->u.xiafs_i.i_dind_zone; |
inode | 229 | fs/xiafs/inode.c | i = zone_bmap(bread(inode->i_dev, i, XIAFS_ZSIZE(inode->i_sb)), |
inode | 230 | fs/xiafs/inode.c | zone >> XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)); |
inode | 232 | fs/xiafs/inode.c | i= zone_bmap(bread(inode->i_dev,i, XIAFS_ZSIZE(inode->i_sb)), |
inode | 233 | fs/xiafs/inode.c | zone & (XIAFS_ADDRS_PER_Z(inode->i_sb)-1)); |
inode | 237 | fs/xiafs/inode.c | static u_long get_prev_addr(struct inode * inode, int zone) |
inode | 243 | fs/xiafs/inode.c | if ((tmp=xiafs_bmap(inode, zone))) |
inode | 245 | fs/xiafs/inode.c | random_nr=(random_nr+23)%inode->i_sb->u.xiafs_sb.s_ndatazones; |
inode | 246 | fs/xiafs/inode.c | return random_nr + inode->i_sb->u.xiafs_sb.s_firstdatazone; |
inode | 250 | fs/xiafs/inode.c | dt_getblk(struct inode * inode, u_long *lp, int create, u_long prev_addr) |
inode | 257 | fs/xiafs/inode.c | result = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 265 | fs/xiafs/inode.c | tmp = xiafs_new_zone(inode->i_sb, prev_addr); |
inode | 268 | fs/xiafs/inode.c | result = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 270 | fs/xiafs/inode.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 275 | fs/xiafs/inode.c | inode->i_blocks+=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 280 | fs/xiafs/inode.c | indt_getblk(struct inode * inode, struct buffer_head * bh, |
inode | 300 | fs/xiafs/inode.c | result = getblk(bh->b_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 312 | fs/xiafs/inode.c | tmp = xiafs_new_zone(inode->i_sb, prev_addr); |
inode | 317 | fs/xiafs/inode.c | result = getblk(bh->b_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 319 | fs/xiafs/inode.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 324 | fs/xiafs/inode.c | inode->i_blocks+=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 330 | fs/xiafs/inode.c | struct buffer_head * xiafs_getblk(struct inode * inode, int zone, int create) |
inode | 339 | fs/xiafs/inode.c | if (zone >= 8+(1+XIAFS_ADDRS_PER_Z(inode->i_sb))*XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 345 | fs/xiafs/inode.c | prev_addr=get_prev_addr(inode, zone); |
inode | 347 | fs/xiafs/inode.c | return dt_getblk(inode, zone+inode->u.xiafs_i.i_zone, create, prev_addr); |
inode | 349 | fs/xiafs/inode.c | if (zone < XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 350 | fs/xiafs/inode.c | bh = dt_getblk(inode, &(inode->u.xiafs_i.i_ind_zone), create, prev_addr); |
inode | 351 | fs/xiafs/inode.c | bh = indt_getblk(inode, bh, zone, create, prev_addr); |
inode | 354 | fs/xiafs/inode.c | zone -= XIAFS_ADDRS_PER_Z(inode->i_sb); |
inode | 355 | fs/xiafs/inode.c | bh = dt_getblk(inode, &(inode->u.xiafs_i.i_dind_zone), create, prev_addr); |
inode | 356 | fs/xiafs/inode.c | bh = indt_getblk(inode, bh, zone>>XIAFS_ADDRS_PER_Z_BITS(inode->i_sb), |
inode | 358 | fs/xiafs/inode.c | bh = indt_getblk(inode, bh, zone&(XIAFS_ADDRS_PER_Z(inode->i_sb)-1), |
inode | 363 | fs/xiafs/inode.c | struct buffer_head * xiafs_bread(struct inode * inode, int zone, int create) |
inode | 367 | fs/xiafs/inode.c | bh = xiafs_getblk(inode, zone, create); |
inode | 378 | fs/xiafs/inode.c | void xiafs_read_inode(struct inode * inode) |
inode | 385 | fs/xiafs/inode.c | ino = inode->i_ino; |
inode | 386 | fs/xiafs/inode.c | inode->i_op = NULL; |
inode | 387 | fs/xiafs/inode.c | inode->i_mode=0; |
inode | 388 | fs/xiafs/inode.c | if (!ino || ino > inode->i_sb->u.xiafs_sb.s_ninodes) { |
inode | 392 | fs/xiafs/inode.c | zone = 1 + inode->i_sb->u.xiafs_sb.s_imap_zones + |
inode | 393 | fs/xiafs/inode.c | inode->i_sb->u.xiafs_sb.s_zmap_zones + |
inode | 394 | fs/xiafs/inode.c | (ino-1)/ XIAFS_INODES_PER_Z(inode->i_sb); |
inode | 395 | fs/xiafs/inode.c | if (!(bh=bread(inode->i_dev, zone, XIAFS_ZSIZE(inode->i_sb)))) { |
inode | 400 | fs/xiafs/inode.c | ((ino-1) & (XIAFS_INODES_PER_Z(inode->i_sb) - 1)); |
inode | 401 | fs/xiafs/inode.c | inode->i_mode = raw_inode->i_mode; |
inode | 402 | fs/xiafs/inode.c | inode->i_uid = raw_inode->i_uid; |
inode | 403 | fs/xiafs/inode.c | inode->i_gid = raw_inode->i_gid; |
inode | 404 | fs/xiafs/inode.c | inode->i_nlink = raw_inode->i_nlinks; |
inode | 405 | fs/xiafs/inode.c | inode->i_size = raw_inode->i_size; |
inode | 406 | fs/xiafs/inode.c | inode->i_mtime = raw_inode->i_mtime; |
inode | 407 | fs/xiafs/inode.c | inode->i_atime = raw_inode->i_atime; |
inode | 408 | fs/xiafs/inode.c | inode->i_ctime = raw_inode->i_ctime; |
inode | 409 | fs/xiafs/inode.c | inode->i_blksize = XIAFS_ZSIZE(inode->i_sb); |
inode | 410 | fs/xiafs/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) { |
inode | 411 | fs/xiafs/inode.c | inode->i_blocks=0; |
inode | 412 | fs/xiafs/inode.c | inode->i_rdev = raw_inode->i_zone[0]; |
inode | 414 | fs/xiafs/inode.c | XIAFS_GET_BLOCKS(raw_inode, inode->i_blocks); |
inode | 416 | fs/xiafs/inode.c | inode->u.xiafs_i.i_zone[zone] = raw_inode->i_zone[zone] & 0xffffff; |
inode | 417 | fs/xiafs/inode.c | inode->u.xiafs_i.i_ind_zone = raw_inode->i_ind_zone & 0xffffff; |
inode | 418 | fs/xiafs/inode.c | inode->u.xiafs_i.i_dind_zone = raw_inode->i_dind_zone & 0xffffff; |
inode | 421 | fs/xiafs/inode.c | if (S_ISREG(inode->i_mode)) |
inode | 422 | fs/xiafs/inode.c | inode->i_op = &xiafs_file_inode_operations; |
inode | 423 | fs/xiafs/inode.c | else if (S_ISDIR(inode->i_mode)) |
inode | 424 | fs/xiafs/inode.c | inode->i_op = &xiafs_dir_inode_operations; |
inode | 425 | fs/xiafs/inode.c | else if (S_ISLNK(inode->i_mode)) |
inode | 426 | fs/xiafs/inode.c | inode->i_op = &xiafs_symlink_inode_operations; |
inode | 427 | fs/xiafs/inode.c | else if (S_ISCHR(inode->i_mode)) |
inode | 428 | fs/xiafs/inode.c | inode->i_op = &chrdev_inode_operations; |
inode | 429 | fs/xiafs/inode.c | else if (S_ISBLK(inode->i_mode)) |
inode | 430 | fs/xiafs/inode.c | inode->i_op = &blkdev_inode_operations; |
inode | 431 | fs/xiafs/inode.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 432 | fs/xiafs/inode.c | init_fifo(inode); |
inode | 435 | fs/xiafs/inode.c | static struct buffer_head * xiafs_update_inode(struct inode * inode) |
inode | 442 | fs/xiafs/inode.c | if (IS_RDONLY (inode)) { |
inode | 444 | fs/xiafs/inode.c | inode->i_dirt = 0; |
inode | 448 | fs/xiafs/inode.c | ino = inode->i_ino; |
inode | 449 | fs/xiafs/inode.c | if (!ino || ino > inode->i_sb->u.xiafs_sb.s_ninodes) { |
inode | 451 | fs/xiafs/inode.c | inode->i_dirt=0; |
inode | 454 | fs/xiafs/inode.c | zone = 1 + inode->i_sb->u.xiafs_sb.s_imap_zones + |
inode | 455 | fs/xiafs/inode.c | inode->i_sb->u.xiafs_sb.s_zmap_zones + |
inode | 456 | fs/xiafs/inode.c | (ino-1) / XIAFS_INODES_PER_Z(inode->i_sb); |
inode | 457 | fs/xiafs/inode.c | if (!(bh=bread(inode->i_dev, zone, XIAFS_ZSIZE(inode->i_sb)))) { |
inode | 459 | fs/xiafs/inode.c | inode->i_dirt=0; |
inode | 463 | fs/xiafs/inode.c | ((ino-1) & (XIAFS_INODES_PER_Z(inode->i_sb) -1)); |
inode | 464 | fs/xiafs/inode.c | raw_inode->i_mode = inode->i_mode; |
inode | 465 | fs/xiafs/inode.c | raw_inode->i_uid = inode->i_uid; |
inode | 466 | fs/xiafs/inode.c | raw_inode->i_gid = inode->i_gid; |
inode | 467 | fs/xiafs/inode.c | raw_inode->i_nlinks = inode->i_nlink; |
inode | 468 | fs/xiafs/inode.c | raw_inode->i_size = inode->i_size; |
inode | 469 | fs/xiafs/inode.c | raw_inode->i_atime = inode->i_atime; |
inode | 470 | fs/xiafs/inode.c | raw_inode->i_ctime = inode->i_ctime; |
inode | 471 | fs/xiafs/inode.c | raw_inode->i_mtime = inode->i_mtime; |
inode | 472 | fs/xiafs/inode.c | if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) |
inode | 473 | fs/xiafs/inode.c | raw_inode->i_zone[0] = inode->i_rdev; |
inode | 475 | fs/xiafs/inode.c | XIAFS_PUT_BLOCKS(raw_inode, inode->i_blocks); |
inode | 478 | fs/xiafs/inode.c | | (inode->u.xiafs_i.i_zone[zone] & 0xffffff); |
inode | 480 | fs/xiafs/inode.c | | (inode->u.xiafs_i.i_ind_zone & 0xffffff); |
inode | 482 | fs/xiafs/inode.c | | (inode->u.xiafs_i.i_dind_zone & 0xffffff); |
inode | 484 | fs/xiafs/inode.c | inode->i_dirt=0; |
inode | 490 | fs/xiafs/inode.c | void xiafs_write_inode(struct inode * inode) |
inode | 493 | fs/xiafs/inode.c | bh = xiafs_update_inode(inode); |
inode | 497 | fs/xiafs/inode.c | int xiafs_sync_inode (struct inode *inode) |
inode | 502 | fs/xiafs/inode.c | bh = xiafs_update_inode(inode); |
inode | 510 | fs/xiafs/inode.c | inode->i_dev, inode->i_ino); |
inode | 61 | fs/xiafs/namei.c | xiafs_find_entry(struct inode * inode, const char * name, int namelen, |
inode | 69 | fs/xiafs/namei.c | if (!inode) |
inode | 74 | fs/xiafs/namei.c | if (inode->i_size & (XIAFS_ZSIZE(inode->i_sb) - 1)) { |
inode | 78 | fs/xiafs/namei.c | zones=inode->i_size >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 80 | fs/xiafs/namei.c | bh = xiafs_bread(inode, i, 0); |
inode | 91 | fs/xiafs/namei.c | while ( pos < XIAFS_ZSIZE(inode->i_sb) ) { |
inode | 92 | fs/xiafs/namei.c | if (dep->d_ino > inode->i_sb->u.xiafs_sb.s_ninodes || |
inode | 94 | fs/xiafs/namei.c | dep->d_rec_len+(char *)dep > bh->b_data+XIAFS_ZSIZE(inode->i_sb) || |
inode | 111 | fs/xiafs/namei.c | if (pos > XIAFS_ZSIZE(inode->i_sb)) { |
inode | 119 | fs/xiafs/namei.c | int xiafs_lookup(struct inode * dir, const char * name, int len, |
inode | 120 | fs/xiafs/namei.c | struct inode ** result) |
inode | 157 | fs/xiafs/namei.c | static struct buffer_head * xiafs_add_entry(struct inode * dir, |
inode | 248 | fs/xiafs/namei.c | int xiafs_create(struct inode * dir, const char * name, int len, int mode, |
inode | 249 | fs/xiafs/namei.c | struct inode ** result) |
inode | 251 | fs/xiafs/namei.c | struct inode * inode; |
inode | 258 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
inode | 259 | fs/xiafs/namei.c | if (!inode) { |
inode | 263 | fs/xiafs/namei.c | inode->i_op = &xiafs_file_inode_operations; |
inode | 264 | fs/xiafs/namei.c | inode->i_mode = mode; |
inode | 265 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 268 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 269 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 270 | fs/xiafs/namei.c | iput(inode); |
inode | 274 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 278 | fs/xiafs/namei.c | *result = inode; |
inode | 282 | fs/xiafs/namei.c | int xiafs_mknod(struct inode *dir, const char *name, int len, int mode, int rdev) |
inode | 284 | fs/xiafs/namei.c | struct inode * inode; |
inode | 296 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
inode | 297 | fs/xiafs/namei.c | if (!inode) { |
inode | 301 | fs/xiafs/namei.c | inode->i_uid = current->fsuid; |
inode | 302 | fs/xiafs/namei.c | inode->i_mode = mode; |
inode | 303 | fs/xiafs/namei.c | inode->i_op = NULL; |
inode | 304 | fs/xiafs/namei.c | if (S_ISREG(inode->i_mode)) |
inode | 305 | fs/xiafs/namei.c | inode->i_op = &xiafs_file_inode_operations; |
inode | 306 | fs/xiafs/namei.c | else if (S_ISDIR(inode->i_mode)) { |
inode | 307 | fs/xiafs/namei.c | inode->i_op = &xiafs_dir_inode_operations; |
inode | 309 | fs/xiafs/namei.c | inode->i_mode |= S_ISGID; |
inode | 311 | fs/xiafs/namei.c | else if (S_ISLNK(inode->i_mode)) |
inode | 312 | fs/xiafs/namei.c | inode->i_op = &xiafs_symlink_inode_operations; |
inode | 313 | fs/xiafs/namei.c | else if (S_ISCHR(inode->i_mode)) |
inode | 314 | fs/xiafs/namei.c | inode->i_op = &chrdev_inode_operations; |
inode | 315 | fs/xiafs/namei.c | else if (S_ISBLK(inode->i_mode)) |
inode | 316 | fs/xiafs/namei.c | inode->i_op = &blkdev_inode_operations; |
inode | 317 | fs/xiafs/namei.c | else if (S_ISFIFO(inode->i_mode)) |
inode | 318 | fs/xiafs/namei.c | init_fifo(inode); |
inode | 320 | fs/xiafs/namei.c | inode->i_rdev = rdev; |
inode | 321 | fs/xiafs/namei.c | inode->i_atime = inode->i_ctime = inode->i_atime = CURRENT_TIME; |
inode | 322 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 325 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 326 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 327 | fs/xiafs/namei.c | iput(inode); |
inode | 331 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 335 | fs/xiafs/namei.c | iput(inode); |
inode | 339 | fs/xiafs/namei.c | int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode) |
inode | 341 | fs/xiafs/namei.c | struct inode * inode; |
inode | 355 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
inode | 356 | fs/xiafs/namei.c | if (!inode) { |
inode | 360 | fs/xiafs/namei.c | inode->i_op = &xiafs_dir_inode_operations; |
inode | 361 | fs/xiafs/namei.c | inode->i_size = XIAFS_ZSIZE(dir->i_sb); |
inode | 362 | fs/xiafs/namei.c | inode->i_atime = inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 363 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 364 | fs/xiafs/namei.c | dir_block = xiafs_bread(inode,0,1); |
inode | 367 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 368 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 369 | fs/xiafs/namei.c | iput(inode); |
inode | 373 | fs/xiafs/namei.c | de->d_ino=inode->i_ino; |
inode | 382 | fs/xiafs/namei.c | inode->i_nlink = 2; |
inode | 385 | fs/xiafs/namei.c | inode->i_mode = S_IFDIR | (mode & S_IRWXUGO & ~current->fs->umask); |
inode | 387 | fs/xiafs/namei.c | inode->i_mode |= S_ISGID; |
inode | 388 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 392 | fs/xiafs/namei.c | inode->i_nlink=0; |
inode | 393 | fs/xiafs/namei.c | iput(inode); |
inode | 396 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 401 | fs/xiafs/namei.c | iput(inode); |
inode | 409 | fs/xiafs/namei.c | static int empty_dir(struct inode * inode) |
inode | 415 | fs/xiafs/namei.c | if (inode->i_size & (XIAFS_ZSIZE(inode->i_sb)-1) ) { |
inode | 420 | fs/xiafs/namei.c | zones=inode->i_size >> XIAFS_ZSIZE_BITS(inode->i_sb); |
inode | 422 | fs/xiafs/namei.c | bh = xiafs_bread(inode, i, 0); |
inode | 429 | fs/xiafs/namei.c | if (de->d_ino != inode->i_ino || strcmp(".", de->d_name) || |
inode | 447 | fs/xiafs/namei.c | while (offset < XIAFS_ZSIZE(inode->i_sb)) { |
inode | 449 | fs/xiafs/namei.c | if (de->d_ino > inode->i_sb->u.xiafs_sb.s_ninodes || |
inode | 451 | fs/xiafs/namei.c | (char *)de+de->d_rec_len > bh->b_data+XIAFS_ZSIZE(inode->i_sb) || |
inode | 489 | fs/xiafs/namei.c | int xiafs_rmdir(struct inode * dir, const char * name, int len) |
inode | 492 | fs/xiafs/namei.c | struct inode * inode; |
inode | 496 | fs/xiafs/namei.c | inode = NULL; |
inode | 502 | fs/xiafs/namei.c | if (!(inode = iget(dir->i_sb, de->d_ino))) |
inode | 505 | fs/xiafs/namei.c | current->fsuid != inode->i_uid && |
inode | 508 | fs/xiafs/namei.c | if (inode->i_dev != dir->i_dev) |
inode | 510 | fs/xiafs/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
inode | 512 | fs/xiafs/namei.c | if (!S_ISDIR(inode->i_mode)) { |
inode | 516 | fs/xiafs/namei.c | if (!empty_dir(inode)) { |
inode | 520 | fs/xiafs/namei.c | if (inode->i_count > 1) { |
inode | 524 | fs/xiafs/namei.c | if (inode->i_nlink != 2) |
inode | 528 | fs/xiafs/namei.c | inode->i_nlink=0; |
inode | 529 | fs/xiafs/namei.c | inode->i_dirt=1; |
inode | 531 | fs/xiafs/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 536 | fs/xiafs/namei.c | iput(inode); |
inode | 541 | fs/xiafs/namei.c | int xiafs_unlink(struct inode * dir, const char * name, int len) |
inode | 544 | fs/xiafs/namei.c | struct inode * inode; |
inode | 550 | fs/xiafs/namei.c | inode = NULL; |
inode | 554 | fs/xiafs/namei.c | if (!(inode = iget(dir->i_sb, de->d_ino))) |
inode | 557 | fs/xiafs/namei.c | if (S_ISDIR(inode->i_mode)) |
inode | 559 | fs/xiafs/namei.c | if (de->d_ino != inode->i_ino) { |
inode | 560 | fs/xiafs/namei.c | iput(inode); |
inode | 567 | fs/xiafs/namei.c | current->fsuid != inode->i_uid && |
inode | 570 | fs/xiafs/namei.c | if (!inode->i_nlink) { |
inode | 572 | fs/xiafs/namei.c | inode->i_nlink=1; |
inode | 576 | fs/xiafs/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
inode | 578 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 579 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 583 | fs/xiafs/namei.c | iput(inode); |
inode | 588 | fs/xiafs/namei.c | int xiafs_symlink(struct inode * dir, const char * name, |
inode | 592 | fs/xiafs/namei.c | struct inode * inode = NULL; |
inode | 603 | fs/xiafs/namei.c | if (!(inode = xiafs_new_inode(dir))) { |
inode | 607 | fs/xiafs/namei.c | inode->i_mode = S_IFLNK | S_IRWXUGO; |
inode | 608 | fs/xiafs/namei.c | inode->i_op = &xiafs_symlink_inode_operations; |
inode | 609 | fs/xiafs/namei.c | name_block = xiafs_bread(inode,0,1); |
inode | 612 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 613 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 614 | fs/xiafs/namei.c | iput(inode); |
inode | 622 | fs/xiafs/namei.c | inode->i_size = i; |
inode | 623 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 626 | fs/xiafs/namei.c | inode->i_nlink--; |
inode | 627 | fs/xiafs/namei.c | inode->i_dirt = 1; |
inode | 628 | fs/xiafs/namei.c | iput(inode); |
inode | 632 | fs/xiafs/namei.c | de->d_ino = inode->i_ino; |
inode | 636 | fs/xiafs/namei.c | iput(inode); |
inode | 640 | fs/xiafs/namei.c | int xiafs_link(struct inode * oldinode, struct inode * dir, |
inode | 680 | fs/xiafs/namei.c | static int subdir(struct inode * new_inode, struct inode * old_inode) |
inode | 717 | fs/xiafs/namei.c | static int do_xiafs_rename(struct inode * old_dir, const char * old_name, |
inode | 718 | fs/xiafs/namei.c | int old_len, struct inode * new_dir, |
inode | 721 | fs/xiafs/namei.c | struct inode * old_inode, * new_inode; |
inode | 837 | fs/xiafs/namei.c | int xiafs_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 838 | fs/xiafs/namei.c | struct inode * new_dir, const char * new_name, int new_len) |
inode | 25 | fs/xiafs/symlink.c | xiafs_readlink(struct inode *, char *, int); |
inode | 28 | fs/xiafs/symlink.c | xiafs_follow_link(struct inode *, struct inode *, int, int, struct inode **); |
inode | 51 | fs/xiafs/symlink.c | static int xiafs_readlink(struct inode * inode, char * buffer, int buflen) |
inode | 57 | fs/xiafs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 58 | fs/xiafs/symlink.c | iput(inode); |
inode | 63 | fs/xiafs/symlink.c | bh = xiafs_bread(inode, 0, 0); |
inode | 64 | fs/xiafs/symlink.c | if (!IS_RDONLY (inode)) { |
inode | 65 | fs/xiafs/symlink.c | inode->i_atime=CURRENT_TIME; |
inode | 66 | fs/xiafs/symlink.c | inode->i_dirt=1; |
inode | 68 | fs/xiafs/symlink.c | iput(inode); |
inode | 79 | fs/xiafs/symlink.c | static int xiafs_follow_link(struct inode * dir, struct inode * inode, |
inode | 80 | fs/xiafs/symlink.c | int flag, int mode, struct inode ** res_inode) |
inode | 90 | fs/xiafs/symlink.c | if (!inode) { |
inode | 94 | fs/xiafs/symlink.c | if (!S_ISLNK(inode->i_mode)) { |
inode | 96 | fs/xiafs/symlink.c | *res_inode = inode; |
inode | 99 | fs/xiafs/symlink.c | if (!IS_RDONLY (inode)) { |
inode | 100 | fs/xiafs/symlink.c | inode->i_atime=CURRENT_TIME; |
inode | 101 | fs/xiafs/symlink.c | inode->i_dirt=1; |
inode | 104 | fs/xiafs/symlink.c | iput(inode); |
inode | 108 | fs/xiafs/symlink.c | if (!(bh = xiafs_bread(inode, 0, 0))) { |
inode | 109 | fs/xiafs/symlink.c | iput(inode); |
inode | 113 | fs/xiafs/symlink.c | iput(inode); |
inode | 39 | fs/xiafs/truncate.c | #define DT_ZONE ((inode->i_size + XIAFS_ZSIZE(inode->i_sb) - 1) \ |
inode | 40 | fs/xiafs/truncate.c | >> XIAFS_ZSIZE_BITS(inode->i_sb) ) |
inode | 42 | fs/xiafs/truncate.c | static int trunc_direct(struct inode * inode) |
inode | 53 | fs/xiafs/truncate.c | lp=i + inode->u.xiafs_i.i_zone; |
inode | 56 | fs/xiafs/truncate.c | bh = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 65 | fs/xiafs/truncate.c | inode->i_dirt = 1; |
inode | 66 | fs/xiafs/truncate.c | inode->i_blocks-=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 67 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 74 | fs/xiafs/truncate.c | static int trunc_indirect(struct inode * inode, int addr_off, u_long * lp) |
inode | 86 | fs/xiafs/truncate.c | ind_bh = bread(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 96 | fs/xiafs/truncate.c | for (i = INDT_ZONE<0?0:INDT_ZONE; i < XIAFS_ADDRS_PER_Z(inode->i_sb); i++) { |
inode | 102 | fs/xiafs/truncate.c | bh = getblk(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 112 | fs/xiafs/truncate.c | inode->i_blocks-= 2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 113 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 118 | fs/xiafs/truncate.c | for (i = 0; i < XIAFS_ADDRS_PER_Z(inode->i_sb) && !(*indp++); i++) ; |
inode | 119 | fs/xiafs/truncate.c | if (i >= XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 125 | fs/xiafs/truncate.c | inode->i_blocks-= 2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 126 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 133 | fs/xiafs/truncate.c | static int trunc_dindirect(struct inode * inode) |
inode | 137 | fs/xiafs/truncate.c | ((DT_ZONE-XIAFS_ADDRS_PER_Z(inode->i_sb)-8)>>XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)) |
inode | 144 | fs/xiafs/truncate.c | lp = &(inode->u.xiafs_i.i_dind_zone); |
inode | 147 | fs/xiafs/truncate.c | dind_bh = bread(inode->i_dev, tmp, XIAFS_ZSIZE(inode->i_sb)); |
inode | 157 | fs/xiafs/truncate.c | for (i=DINDT_ZONE<0?0:DINDT_ZONE ; i < XIAFS_ADDRS_PER_Z(inode->i_sb) ; i ++) { |
inode | 161 | fs/xiafs/truncate.c | retry |= trunc_indirect(inode, |
inode | 162 | fs/xiafs/truncate.c | 8+((1+i)<<XIAFS_ADDRS_PER_Z_BITS(inode->i_sb)), |
inode | 167 | fs/xiafs/truncate.c | for (i = 0; i < XIAFS_ADDRS_PER_Z(inode->i_sb) && !(*dindp++); i++); |
inode | 168 | fs/xiafs/truncate.c | if (i >= XIAFS_ADDRS_PER_Z(inode->i_sb)) { |
inode | 174 | fs/xiafs/truncate.c | inode->i_dirt = 1; |
inode | 175 | fs/xiafs/truncate.c | inode->i_blocks-=2 << XIAFS_ZSHIFT(inode->i_sb); |
inode | 176 | fs/xiafs/truncate.c | xiafs_free_zone(inode->i_sb, tmp); |
inode | 183 | fs/xiafs/truncate.c | void xiafs_truncate(struct inode * inode) |
inode | 187 | fs/xiafs/truncate.c | if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) || |
inode | 188 | fs/xiafs/truncate.c | S_ISLNK(inode->i_mode))) |
inode | 191 | fs/xiafs/truncate.c | retry = trunc_direct(inode); |
inode | 192 | fs/xiafs/truncate.c | retry |= trunc_indirect(inode, 8, &(inode->u.xiafs_i.i_ind_zone)); |
inode | 193 | fs/xiafs/truncate.c | retry |= trunc_dindirect(inode); |
inode | 199 | fs/xiafs/truncate.c | inode->i_ctime = inode->i_mtime = CURRENT_TIME; |
inode | 200 | fs/xiafs/truncate.c | inode->i_dirt = 1; |
inode | 21 | include/linux/binfmts.h | struct inode * inode; |
inode | 42 | include/linux/binfmts.h | extern int read_exec(struct inode *inode, unsigned long offset, |
inode | 45 | include/linux/binfmts.h | extern int open_inode(struct inode * inode, int mode); |
inode | 374 | include/linux/ext2_fs.h | __u32 inode; /* Inode number */ |
inode | 410 | include/linux/ext2_fs.h | extern int ext2_permission (struct inode *, int); |
inode | 424 | include/linux/ext2_fs.h | extern int ext2_check_dir_entry (char *, struct inode *, |
inode | 429 | include/linux/ext2_fs.h | extern int ext2_read (struct inode *, struct file *, char *, int); |
inode | 430 | include/linux/ext2_fs.h | extern int ext2_write (struct inode *, struct file *, char *, int); |
inode | 433 | include/linux/ext2_fs.h | extern int ext2_sync_file (struct inode *, struct file *); |
inode | 436 | include/linux/ext2_fs.h | extern struct inode * ext2_new_inode (const struct inode *, int); |
inode | 437 | include/linux/ext2_fs.h | extern void ext2_free_inode (struct inode *); |
inode | 442 | include/linux/ext2_fs.h | extern int ext2_bmap (struct inode *, int); |
inode | 444 | include/linux/ext2_fs.h | extern struct buffer_head * ext2_getblk (struct inode *, long, int, int *); |
inode | 445 | include/linux/ext2_fs.h | extern struct buffer_head * ext2_bread (struct inode *, int, int, int *); |
inode | 447 | include/linux/ext2_fs.h | extern int ext2_getcluster (struct inode * inode, long block); |
inode | 448 | include/linux/ext2_fs.h | extern void ext2_read_inode (struct inode *); |
inode | 449 | include/linux/ext2_fs.h | extern void ext2_write_inode (struct inode *); |
inode | 450 | include/linux/ext2_fs.h | extern void ext2_put_inode (struct inode *); |
inode | 451 | include/linux/ext2_fs.h | extern int ext2_sync_inode (struct inode *); |
inode | 452 | include/linux/ext2_fs.h | extern void ext2_discard_prealloc (struct inode *); |
inode | 455 | include/linux/ext2_fs.h | extern int ext2_ioctl (struct inode *, struct file *, unsigned int, |
inode | 459 | include/linux/ext2_fs.h | extern void ext2_release (struct inode *, struct file *); |
inode | 460 | include/linux/ext2_fs.h | extern int ext2_lookup (struct inode *,const char *, int, struct inode **); |
inode | 461 | include/linux/ext2_fs.h | extern int ext2_create (struct inode *,const char *, int, int, |
inode | 462 | include/linux/ext2_fs.h | struct inode **); |
inode | 463 | include/linux/ext2_fs.h | extern int ext2_mkdir (struct inode *, const char *, int, int); |
inode | 464 | include/linux/ext2_fs.h | extern int ext2_rmdir (struct inode *, const char *, int); |
inode | 465 | include/linux/ext2_fs.h | extern int ext2_unlink (struct inode *, const char *, int); |
inode | 466 | include/linux/ext2_fs.h | extern int ext2_symlink (struct inode *, const char *, int, const char *); |
inode | 467 | include/linux/ext2_fs.h | extern int ext2_link (struct inode *, struct inode *, const char *, int); |
inode | 468 | include/linux/ext2_fs.h | extern int ext2_mknod (struct inode *, const char *, int, int, int); |
inode | 469 | include/linux/ext2_fs.h | extern int ext2_rename (struct inode *, const char *, int, |
inode | 470 | include/linux/ext2_fs.h | struct inode *, const char *, int); |
inode | 487 | 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 | 94 | include/linux/ext_fs.h | extern void ext_read_inode(struct inode *); |
inode | 95 | include/linux/ext_fs.h | extern void ext_write_inode(struct inode *); |
inode | 96 | include/linux/ext_fs.h | extern void ext_put_inode(struct inode *); |
inode | 98 | include/linux/ext_fs.h | extern int ext_sync_inode(struct inode *); |
inode | 99 | include/linux/ext_fs.h | extern int ext_sync_file(struct inode *, struct file *); |
inode | 101 | include/linux/ext_fs.h | extern int ext_lseek(struct inode *, struct file *, off_t, int); |
inode | 102 | include/linux/ext_fs.h | extern int ext_read(struct inode *, struct file *, char *, int); |
inode | 103 | include/linux/ext_fs.h | extern int ext_write(struct inode *, struct file *, char *, 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_APPEND(inode) ((inode)->i_flags & S_APPEND) |
inode | 102 | include/linux/fs.h | #define IS_IMMUTABLE(inode) ((inode)->i_flags & S_IMMUTABLE) |
inode | 224 | include/linux/fs.h | struct inode * i_next, * i_prev; |
inode | 225 | include/linux/fs.h | struct inode * i_hash_next, * i_hash_prev; |
inode | 226 | include/linux/fs.h | struct inode * i_bound_to, * i_bound_by; |
inode | 227 | include/linux/fs.h | struct inode * i_mount; |
inode | 262 | include/linux/fs.h | struct inode * f_inode; |
inode | 310 | include/linux/fs.h | struct inode * s_covered; |
inode | 311 | include/linux/fs.h | struct inode * s_mounted; |
inode | 328 | include/linux/fs.h | int (*lseek) (struct inode *, struct file *, off_t, int); |
inode | 329 | include/linux/fs.h | int (*read) (struct inode *, struct file *, char *, int); |
inode | 330 | include/linux/fs.h | int (*write) (struct inode *, struct file *, char *, int); |
inode | 331 | include/linux/fs.h | int (*readdir) (struct inode *, struct file *, struct dirent *, int); |
inode | 332 | include/linux/fs.h | int (*select) (struct inode *, struct file *, int, select_table *); |
inode | 333 | include/linux/fs.h | int (*ioctl) (struct inode *, struct file *, unsigned int, unsigned long); |
inode | 334 | include/linux/fs.h | int (*mmap) (struct inode *, struct file *, struct vm_area_struct *); |
inode | 335 | include/linux/fs.h | int (*open) (struct inode *, struct file *); |
inode | 336 | include/linux/fs.h | void (*release) (struct inode *, struct file *); |
inode | 337 | include/linux/fs.h | int (*fsync) (struct inode *, struct file *); |
inode | 338 | include/linux/fs.h | int (*fasync) (struct inode *, struct file *, int); |
inode | 345 | include/linux/fs.h | int (*create) (struct inode *,const char *,int,int,struct inode **); |
inode | 346 | include/linux/fs.h | int (*lookup) (struct inode *,const char *,int,struct inode **); |
inode | 347 | include/linux/fs.h | int (*link) (struct inode *,struct inode *,const char *,int); |
inode | 348 | include/linux/fs.h | int (*unlink) (struct inode *,const char *,int); |
inode | 349 | include/linux/fs.h | int (*symlink) (struct inode *,const char *,int,const char *); |
inode | 350 | include/linux/fs.h | int (*mkdir) (struct inode *,const char *,int,int); |
inode | 351 | include/linux/fs.h | int (*rmdir) (struct inode *,const char *,int); |
inode | 352 | include/linux/fs.h | int (*mknod) (struct inode *,const char *,int,int,int); |
inode | 353 | include/linux/fs.h | int (*rename) (struct inode *,const char *,int,struct inode *,const char *,int); |
inode | 354 | include/linux/fs.h | int (*readlink) (struct inode *,char *,int); |
inode | 355 | include/linux/fs.h | int (*follow_link) (struct inode *,struct inode *,int,int,struct inode **); |
inode | 356 | include/linux/fs.h | int (*bmap) (struct inode *,int); |
inode | 357 | include/linux/fs.h | void (*truncate) (struct inode *); |
inode | 358 | include/linux/fs.h | int (*permission) (struct inode *, int); |
inode | 359 | include/linux/fs.h | int (*smap) (struct inode *,int); |
inode | 363 | include/linux/fs.h | void (*read_inode) (struct inode *); |
inode | 364 | include/linux/fs.h | int (*notify_change) (struct inode *, struct iattr *); |
inode | 365 | include/linux/fs.h | void (*write_inode) (struct inode *); |
inode | 366 | include/linux/fs.h | void (*put_inode) (struct inode *); |
inode | 393 | include/linux/fs.h | extern int blkdev_open(struct inode * inode, struct file * filp); |
inode | 399 | include/linux/fs.h | extern int chrdev_open(struct inode * inode, struct file * filp); |
inode | 403 | include/linux/fs.h | extern void init_fifo(struct inode * inode); |
inode | 416 | include/linux/fs.h | extern int fs_may_umount(dev_t dev, struct inode * mount_root); |
inode | 467 | include/linux/fs.h | extern int bmap(struct inode * inode,int block); |
inode | 468 | include/linux/fs.h | extern int notify_change(struct inode *, struct iattr *); |
inode | 469 | include/linux/fs.h | extern int namei(const char * pathname, struct inode ** res_inode); |
inode | 470 | include/linux/fs.h | extern int lnamei(const char * pathname, struct inode ** res_inode); |
inode | 471 | include/linux/fs.h | extern int permission(struct inode * inode,int mask); |
inode | 472 | include/linux/fs.h | extern int get_write_access(struct inode * inode); |
inode | 473 | include/linux/fs.h | extern void put_write_access(struct inode * inode); |
inode | 475 | include/linux/fs.h | struct inode ** res_inode, struct inode * base); |
inode | 477 | include/linux/fs.h | extern void iput(struct inode * inode); |
inode | 478 | include/linux/fs.h | extern struct inode * __iget(struct super_block * sb,int nr,int crsmnt); |
inode | 479 | include/linux/fs.h | extern struct inode * get_empty_inode(void); |
inode | 480 | include/linux/fs.h | extern void insert_inode_hash(struct inode *); |
inode | 481 | include/linux/fs.h | extern void clear_inode(struct inode *); |
inode | 482 | include/linux/fs.h | extern struct inode * get_pipe_inode(void); |
inode | 503 | include/linux/fs.h | extern int char_read(struct inode *, struct file *, char *, int); |
inode | 504 | include/linux/fs.h | extern int block_read(struct inode *, struct file *, char *, int); |
inode | 507 | include/linux/fs.h | extern int char_write(struct inode *, struct file *, char *, int); |
inode | 508 | include/linux/fs.h | extern int block_write(struct inode *, struct file *, char *, int); |
inode | 510 | include/linux/fs.h | extern int generic_mmap(struct inode *, struct file *, struct vm_area_struct *); |
inode | 512 | include/linux/fs.h | extern int block_fsync(struct inode *, struct file *); |
inode | 513 | include/linux/fs.h | extern int file_fsync(struct inode *, struct file *); |
inode | 515 | include/linux/fs.h | extern void dcache_add(struct inode *, const char *, int, unsigned long); |
inode | 516 | include/linux/fs.h | extern int dcache_lookup(struct inode *, const char *, int, unsigned long *); |
inode | 518 | include/linux/fs.h | extern int inode_change_ok(struct inode *, struct iattr *); |
inode | 519 | include/linux/fs.h | extern void inode_setattr(struct inode *, struct iattr *); |
inode | 521 | include/linux/fs.h | extern inline struct inode * iget(struct super_block * sb,int nr) |
inode | 158 | include/linux/iso_fs.h | extern int parse_rock_ridge_inode(struct iso_directory_record *, struct inode *); |
inode | 159 | include/linux/iso_fs.h | extern int get_rock_ridge_filename(struct iso_directory_record *, char ** name, int * len, struct inode *); |
inode | 161 | include/linux/iso_fs.h | extern char * get_rock_ridge_symlink(struct inode *); |
inode | 162 | include/linux/iso_fs.h | extern int find_rock_ridge_relocation(struct iso_directory_record *, struct inode *); |
inode | 167 | include/linux/iso_fs.h | extern int isofs_open(struct inode * inode, struct file * filp); |
inode | 168 | include/linux/iso_fs.h | extern void isofs_release(struct inode * inode, struct file * filp); |
inode | 169 | include/linux/iso_fs.h | extern int isofs_lookup(struct inode * dir,const char * name, int len, |
inode | 170 | include/linux/iso_fs.h | struct inode ** result); |
inode | 174 | include/linux/iso_fs.h | extern int isofs_bmap(struct inode *,int); |
inode | 178 | include/linux/iso_fs.h | extern void isofs_read_inode(struct inode *); |
inode | 179 | include/linux/iso_fs.h | extern void isofs_put_inode(struct inode *); |
inode | 182 | include/linux/iso_fs.h | extern int isofs_lseek(struct inode *, struct file *, off_t, int); |
inode | 183 | include/linux/iso_fs.h | extern int isofs_read(struct inode *, struct file *, char *, int); |
inode | 184 | include/linux/iso_fs.h | extern int isofs_lookup_grandparent(struct inode *, int); |
inode | 78 | include/linux/minix_fs.h | __u16 inode; |
inode | 84 | include/linux/minix_fs.h | extern int minix_lookup(struct inode * dir,const char * name, int len, |
inode | 85 | include/linux/minix_fs.h | struct inode ** result); |
inode | 86 | include/linux/minix_fs.h | extern int minix_create(struct inode * dir,const char * name, int len, int mode, |
inode | 87 | include/linux/minix_fs.h | struct inode ** result); |
inode | 88 | include/linux/minix_fs.h | extern int minix_mkdir(struct inode * dir, const char * name, int len, int mode); |
inode | 89 | include/linux/minix_fs.h | extern int minix_rmdir(struct inode * dir, const char * name, int len); |
inode | 90 | include/linux/minix_fs.h | extern int minix_unlink(struct inode * dir, const char * name, int len); |
inode | 91 | include/linux/minix_fs.h | extern int minix_symlink(struct inode * inode, const char * name, int len, |
inode | 93 | include/linux/minix_fs.h | extern int minix_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
inode | 94 | include/linux/minix_fs.h | extern int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
inode | 95 | include/linux/minix_fs.h | extern int minix_rename(struct inode * old_dir, const char * old_name, int old_len, |
inode | 96 | include/linux/minix_fs.h | struct inode * new_dir, const char * new_name, int new_len); |
inode | 97 | include/linux/minix_fs.h | extern struct inode * minix_new_inode(const struct inode * dir); |
inode | 98 | include/linux/minix_fs.h | extern void minix_free_inode(struct inode * inode); |
inode | 104 | include/linux/minix_fs.h | extern int minix_bmap(struct inode *,int); |
inode | 106 | include/linux/minix_fs.h | extern struct buffer_head * minix_getblk(struct inode *, int, int); |
inode | 107 | include/linux/minix_fs.h | extern struct buffer_head * minix_bread(struct inode *, int, int); |
inode | 109 | include/linux/minix_fs.h | extern void minix_truncate(struct inode *); |
inode | 114 | include/linux/minix_fs.h | extern void minix_read_inode(struct inode *); |
inode | 115 | include/linux/minix_fs.h | extern void minix_write_inode(struct inode *); |
inode | 116 | include/linux/minix_fs.h | extern void minix_put_inode(struct inode *); |
inode | 118 | include/linux/minix_fs.h | extern int minix_sync_inode(struct inode *); |
inode | 119 | include/linux/minix_fs.h | extern int minix_sync_file(struct inode *, struct file *); |
inode | 55 | include/linux/mm.h | struct inode * vm_inode; |
inode | 119 | include/linux/mm.h | struct inode * inode; |
inode | 121 | include/linux/msdos_fs.h | extern int msdos_add_cluster(struct inode *inode); |
inode | 124 | include/linux/msdos_fs.h | extern int msdos_get_entry(struct inode *dir,loff_t *pos,struct buffer_head **bh, |
inode | 126 | include/linux/msdos_fs.h | extern int msdos_scan(struct inode *dir,char *name,struct buffer_head **res_bh, |
inode | 128 | include/linux/msdos_fs.h | extern int msdos_parent_ino(struct inode *dir,int locked); |
inode | 129 | include/linux/msdos_fs.h | extern int msdos_subdirs(struct inode *dir); |
inode | 134 | include/linux/msdos_fs.h | extern int msdos_smap(struct inode *inode,int sector); |
inode | 135 | include/linux/msdos_fs.h | extern int fat_free(struct inode *inode,int skip); |
inode | 137 | include/linux/msdos_fs.h | void cache_lookup(struct inode *inode,int cluster,int *f_clu,int *d_clu); |
inode | 138 | include/linux/msdos_fs.h | void cache_add(struct inode *inode,int f_clu,int d_clu); |
inode | 139 | include/linux/msdos_fs.h | void cache_inval_inode(struct inode *inode); |
inode | 141 | include/linux/msdos_fs.h | int get_cluster(struct inode *inode,int cluster); |
inode | 145 | include/linux/msdos_fs.h | extern int msdos_lookup(struct inode *dir,const char *name,int len, |
inode | 146 | include/linux/msdos_fs.h | struct inode **result); |
inode | 147 | include/linux/msdos_fs.h | extern int msdos_create(struct inode *dir,const char *name,int len,int mode, |
inode | 148 | include/linux/msdos_fs.h | struct inode **result); |
inode | 149 | include/linux/msdos_fs.h | extern int msdos_mkdir(struct inode *dir,const char *name,int len,int mode); |
inode | 150 | include/linux/msdos_fs.h | extern int msdos_rmdir(struct inode *dir,const char *name,int len); |
inode | 151 | include/linux/msdos_fs.h | extern int msdos_unlink(struct inode *dir,const char *name,int len); |
inode | 152 | include/linux/msdos_fs.h | extern int msdos_unlink_umsdos(struct inode *dir,const char *name,int len); |
inode | 153 | include/linux/msdos_fs.h | extern int msdos_rename(struct inode *old_dir,const char *old_name,int old_len, |
inode | 154 | include/linux/msdos_fs.h | struct inode *new_dir,const char *new_name,int new_len); |
inode | 158 | include/linux/msdos_fs.h | extern void msdos_put_inode(struct inode *inode); |
inode | 163 | include/linux/msdos_fs.h | extern int msdos_bmap(struct inode *inode,int block); |
inode | 164 | include/linux/msdos_fs.h | extern void msdos_read_inode(struct inode *inode); |
inode | 165 | include/linux/msdos_fs.h | extern void msdos_write_inode(struct inode *inode); |
inode | 166 | include/linux/msdos_fs.h | extern int msdos_notify_change(struct inode *,struct iattr *); |
inode | 171 | include/linux/msdos_fs.h | extern int msdos_readdir (struct inode *inode, struct file *filp, |
inode | 177 | include/linux/msdos_fs.h | extern int msdos_file_read(struct inode *, struct file *, char *, int); |
inode | 178 | include/linux/msdos_fs.h | extern int msdos_file_write(struct inode *, struct file *, char *, int); |
inode | 181 | include/linux/msdos_fs.h | extern void msdos_truncate(struct inode *inode); |
inode | 184 | include/linux/msdos_fs.h | extern int msdos_mmap(struct inode *, struct file *, struct vm_area_struct *); |
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 | 82 | include/linux/net.h | struct inode *inode; |
inode | 86 | include/linux/net.h | #define SOCK_INODE(S) ((S)->inode) |
inode | 45 | include/linux/nfs_fs.h | #define NFS_SERVER(inode) (&(inode)->i_sb->u.nfs_sb.s_server) |
inode | 46 | include/linux/nfs_fs.h | #define NFS_FH(inode) (&(inode)->u.nfs_i.fhandle) |
inode | 98 | include/linux/nfs_fs.h | extern struct inode *nfs_fhget(struct super_block *sb, struct nfs_fh *fhandle, |
inode | 100 | include/linux/nfs_fs.h | extern void nfs_refresh_inode(struct inode *inode, struct nfs_fattr *fattr); |
inode | 116 | include/linux/nfs_fs.h | extern int nfs_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma); |
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 | 113 | include/linux/proc_fs.h | extern void proc_put_inode(struct inode *); |
inode | 116 | include/linux/proc_fs.h | extern void proc_read_inode(struct inode *); |
inode | 117 | include/linux/proc_fs.h | extern void proc_write_inode(struct inode *); |
inode | 101 | include/linux/sched.h | struct inode * root, * pwd; |
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 | 394 | include/linux/sysv_fs.h | extern void sysv_read_inode(struct inode *); |
inode | 395 | include/linux/sysv_fs.h | extern int sysv_notify_change(struct inode *, struct iattr *); |
inode | 396 | include/linux/sysv_fs.h | extern void sysv_write_inode(struct inode *); |
inode | 397 | include/linux/sysv_fs.h | extern void sysv_put_inode(struct inode *); |
inode | 399 | include/linux/sysv_fs.h | extern int sysv_sync_inode(struct inode *); |
inode | 400 | include/linux/sysv_fs.h | extern int sysv_sync_file(struct inode *, struct file *); |
inode | 401 | 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 | 113 | include/linux/xd.h | static int xd_open (struct inode *inode,struct file *file); |
inode | 115 | include/linux/xd.h | static int xd_ioctl (struct inode *inode,struct file *file,unsigned int cmd,unsigned long arg); |
inode | 116 | 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 | 98 | include/linux/xia_fs.h | extern void xiafs_read_inode(struct inode *); |
inode | 99 | include/linux/xia_fs.h | extern void xiafs_write_inode(struct inode *); |
inode | 100 | include/linux/xia_fs.h | extern void xiafs_put_inode(struct inode *); |
inode | 102 | include/linux/xia_fs.h | extern int xiafs_sync_inode(struct inode *); |
inode | 103 | include/linux/xia_fs.h | extern int xiafs_sync_file(struct inode *, struct file *); |
inode | 432 | init/main.c | extern struct inode *pseudo_root; |
inode | 35 | mm/filemap.c | struct inode * inode = area->vm_inode; |
inode | 42 | mm/filemap.c | block >>= inode->i_sb->s_blocksize_bits; |
inode | 43 | mm/filemap.c | i = PAGE_SIZE >> inode->i_sb->s_blocksize_bits; |
inode | 46 | mm/filemap.c | *p = bmap(inode,block); |
inode | 51 | mm/filemap.c | return bread_page(page, inode->i_dev, nr, inode->i_sb->s_blocksize, no_share); |
inode | 245 | mm/filemap.c | int generic_mmap(struct inode * inode, struct file * file, struct vm_area_struct * vma) |
inode | 249 | mm/filemap.c | if (vma->vm_offset & (inode->i_sb->s_blocksize - 1)) |
inode | 251 | mm/filemap.c | if (!inode->i_sb || !S_ISREG(inode->i_mode)) |
inode | 253 | mm/filemap.c | if (!inode->i_op || !inode->i_op->bmap) |
inode | 267 | mm/filemap.c | if (!IS_RDONLY(inode)) { |
inode | 268 | mm/filemap.c | inode->i_atime = CURRENT_TIME; |
inode | 269 | mm/filemap.c | inode->i_dirt = 1; |
inode | 271 | mm/filemap.c | vma->vm_inode = inode; |
inode | 272 | mm/filemap.c | inode->i_count++; |
inode | 924 | mm/memory.c | struct inode * inode; |
inode | 930 | mm/memory.c | if (!area || !(inode = area->vm_inode) || inode->i_count < 2) |
inode | 944 | mm/memory.c | if (mpnt->vm_inode != inode) { |
inode | 20 | mm/mmap.c | static int anon_map(struct inode *, struct file *, struct vm_area_struct *); |
inode | 826 | mm/mmap.c | struct inode * inode; |
inode | 854 | mm/mmap.c | inode = vmp->vm_inode; |
inode | 855 | mm/mmap.c | if (!inode) |
inode | 859 | mm/mmap.c | if ((share = inode->i_mmap)) { |
inode | 865 | mm/mmap.c | inode->i_mmap = vmp->vm_next_share = vmp->vm_prev_share = vmp; |
inode | 873 | mm/mmap.c | struct inode * inode = mpnt->vm_inode; |
inode | 875 | mm/mmap.c | if (!inode) |
inode | 879 | mm/mmap.c | if (inode->i_mmap != mpnt) |
inode | 881 | mm/mmap.c | inode->i_mmap = NULL; |
inode | 885 | mm/mmap.c | if (inode->i_mmap == mpnt) |
inode | 886 | mm/mmap.c | inode->i_mmap = mpnt->vm_next_share; |
inode | 970 | mm/mmap.c | static int anon_map(struct inode *ino, struct file * file, struct vm_area_struct * vma) |
inode | 44 | mm/swap.c | struct inode * swap_file; |
inode | 140 | mm/swap.c | struct inode *swapf = p->swap_file; |
inode | 979 | mm/swap.c | struct inode * inode; |
inode | 986 | mm/swap.c | i = namei(specialfile,&inode); |
inode | 994 | mm/swap.c | if (p->swap_file == inode) |
inode | 997 | mm/swap.c | if (!S_ISBLK(inode->i_mode)) |
inode | 999 | mm/swap.c | if (p->swap_device == inode->i_rdev) |
inode | 1005 | mm/swap.c | iput(inode); |
inode | 1011 | mm/swap.c | iput(inode); |
inode | 1018 | mm/swap.c | filp.f_inode = inode; |
inode | 1021 | mm/swap.c | if( !blkdev_open(inode, &filp) && |
inode | 1023 | mm/swap.c | filp.f_op->release(inode,&filp); |
inode | 1024 | mm/swap.c | filp.f_op->release(inode,&filp); |
inode | 1027 | mm/swap.c | iput(inode); |
inode | 1049 | mm/swap.c | struct inode * swap_inode; |
inode | 68 | net/socket.c | static int sock_lseek(struct inode *inode, struct file *file, off_t offset, |
inode | 70 | net/socket.c | static int sock_read(struct inode *inode, struct file *file, char *buf, |
inode | 72 | net/socket.c | static int sock_write(struct inode *inode, struct file *file, char *buf, |
inode | 74 | net/socket.c | static int sock_readdir(struct inode *inode, struct file *file, |
inode | 76 | net/socket.c | static void sock_close(struct inode *inode, struct file *file); |
inode | 77 | net/socket.c | static int sock_select(struct inode *inode, struct file *file, int which, select_table *seltable); |
inode | 78 | net/socket.c | static int sock_ioctl(struct inode *inode, struct file *file, |
inode | 80 | net/socket.c | static int sock_fasync(struct inode *inode, struct file *filp, int on); |
inode | 159 | net/socket.c | static int get_fd(struct inode *inode) |
inode | 187 | net/socket.c | file->f_inode = inode; |
inode | 188 | net/socket.c | if (inode) |
inode | 189 | net/socket.c | inode->i_count++; |
inode | 201 | net/socket.c | inline struct socket *socki_lookup(struct inode *inode) |
inode | 203 | net/socket.c | return &inode->u.socket_i; |
inode | 213 | net/socket.c | struct inode *inode; |
inode | 218 | net/socket.c | inode = file->f_inode; |
inode | 219 | net/socket.c | if (!inode || !inode->i_sock) |
inode | 225 | net/socket.c | return socki_lookup(inode); |
inode | 234 | net/socket.c | struct inode * inode; |
inode | 237 | net/socket.c | inode = get_empty_inode(); |
inode | 238 | net/socket.c | if (!inode) |
inode | 241 | net/socket.c | inode->i_mode = S_IFSOCK; |
inode | 242 | net/socket.c | inode->i_sock = 1; |
inode | 243 | net/socket.c | inode->i_uid = current->uid; |
inode | 244 | net/socket.c | inode->i_gid = current->gid; |
inode | 246 | net/socket.c | sock = &inode->u.socket_i; |
inode | 254 | net/socket.c | sock->wait = &inode->i_wait; |
inode | 255 | net/socket.c | sock->inode = inode; /* "backlink": we could use pointer arithmetic instead */ |
inode | 308 | net/socket.c | static int sock_lseek(struct inode *inode, struct file *file, off_t offset, int whence) |
inode | 318 | net/socket.c | static int sock_read(struct inode *inode, struct file *file, char *ubuf, int size) |
inode | 323 | net/socket.c | if (!(sock = socki_lookup(inode))) |
inode | 345 | net/socket.c | static int sock_write(struct inode *inode, struct file *file, char *ubuf, int size) |
inode | 350 | net/socket.c | if (!(sock = socki_lookup(inode))) |
inode | 373 | net/socket.c | static int sock_readdir(struct inode *inode, struct file *file, struct dirent *dirent, |
inode | 384 | net/socket.c | int sock_ioctl(struct inode *inode, struct file *file, unsigned int cmd, |
inode | 389 | net/socket.c | if (!(sock = socki_lookup(inode))) |
inode | 398 | net/socket.c | static int sock_select(struct inode *inode, struct file *file, int sel_type, select_table * wait) |
inode | 402 | net/socket.c | if (!(sock = socki_lookup(inode))) |
inode | 418 | net/socket.c | void sock_close(struct inode *inode, struct file *filp) |
inode | 426 | net/socket.c | if (!inode) |
inode | 429 | net/socket.c | if (!(sock = socki_lookup(inode))) |
inode | 434 | net/socket.c | sock_fasync(inode, filp, 0); |
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 | 216 | net/unix/sock.c | struct inode *inode) |
inode | 225 | net/unix/sock.c | upd->inode == inode) |
inode | 256 | net/unix/sock.c | upd->inode = NULL; |
inode | 365 | net/unix/sock.c | if (upd->inode) |
inode | 367 | net/unix/sock.c | iput(upd->inode); |
inode | 368 | net/unix/sock.c | upd->inode = NULL; |
inode | 404 | net/unix/sock.c | if (upd->sockaddr_len || upd->inode) |
inode | 424 | net/unix/sock.c | i = open_namei(fname, 0, S_IFSOCK, &upd->inode, NULL); |
inode | 451 | net/unix/sock.c | struct inode *inode; |
inode | 484 | net/unix/sock.c | i = open_namei(fname, 0, S_IFSOCK, &inode, NULL); |
inode | 491 | net/unix/sock.c | serv_upd = unix_data_lookup(&sockun, sockaddr_len, inode); |
inode | 492 | net/unix/sock.c | iput(inode); |
inode | 40 | net/unix/unix.h | struct inode *inode; |