tag | line | file | source code |
dir | 282 | arch/alpha/kernel/traps.c | long dir, size; |
dir | 305 | arch/alpha/kernel/traps.c | dir = VERIFY_READ; |
dir | 308 | arch/alpha/kernel/traps.c | dir = VERIFY_WRITE; |
dir | 315 | arch/alpha/kernel/traps.c | if (verify_area(dir, va, size)) { |
dir | 369 | arch/alpha/kernel/traps.c | if (opcode >= 0x28 && reg == 30 && dir == VERIFY_WRITE) { |
dir | 35 | arch/m68k/atari/joystick.c | joystick[j].dir = buf[1] & 0xF; |
dir | 99 | arch/m68k/atari/joystick.c | put_user(joystick[minor].dir, buffer++); |
dir | 235 | arch/m68k/console/fbcon.c | static int fbcon_scroll(struct vc_data *conp, int t, int b, int dir, int count); |
dir | 1509 | arch/m68k/console/fbcon.c | static int fbcon_scroll(struct vc_data *conp, int t, int b, int dir, int count) |
dir | 1523 | arch/m68k/console/fbcon.c | switch (dir) { |
dir | 34 | arch/m68k/console/txtcon.c | static int txtcon_scroll(struct vc_data *conp, int t, int b, int dir, int count); |
dir | 91 | arch/m68k/console/txtcon.c | static int txtcon_scroll(struct vc_data *conp, int t, int b, int dir, int count) |
dir | 712 | arch/m68k/mm/memory.c | static inline void set_cmode_pmd( pgd_t *dir, unsigned long address, |
dir | 718 | arch/m68k/mm/memory.c | if (pgd_none(*dir)) |
dir | 721 | arch/m68k/mm/memory.c | pmd = pmd_offset( dir, address ); |
dir | 751 | arch/m68k/mm/memory.c | pgd_t *dir = pgd_offset_k( address ); |
dir | 775 | arch/m68k/mm/memory.c | for( ; address < end; dir++ ) { |
dir | 776 | arch/m68k/mm/memory.c | set_cmode_pmd( dir, address, end - address, cmode ); |
dir | 37 | arch/ppc/mm/fault.c | pgd_t *dir; |
dir | 64 | arch/ppc/mm/fault.c | dir = pgd_offset(current->mm, regs->dar & PAGE_MASK); |
dir | 65 | arch/ppc/mm/fault.c | if (dir) |
dir | 67 | arch/ppc/mm/fault.c | pmd = pmd_offset(dir, regs->dar & PAGE_MASK); |
dir | 99 | arch/ppc/mm/fault.c | pgd_t *dir; |
dir | 119 | arch/ppc/mm/fault.c | dir = pgd_offset(current->mm, regs->dar & PAGE_MASK); |
dir | 124 | arch/ppc/mm/fault.c | if (dir) |
dir | 126 | arch/ppc/mm/fault.c | pmd = pmd_offset(dir, regs->dar & PAGE_MASK); |
dir | 137 | arch/ppc/mm/fault.c | printk("dir is %x\n", dir); |
dir | 142 | arch/ppc/mm/fault.c | current->mm->pgd,dir,*dir,pmd,*pmd,pte); |
dir | 306 | arch/ppc/mm/fault.c | pgd_t *dir; |
dir | 309 | arch/ppc/mm/fault.c | dir = pgd_offset(current->mm, address & PAGE_MASK); |
dir | 310 | arch/ppc/mm/fault.c | if (dir) |
dir | 312 | arch/ppc/mm/fault.c | pmd = pmd_offset(dir, address & PAGE_MASK); |
dir | 753 | arch/sparc/kernel/sys_sunos.c | sunos_mount(char *type, char *dir, int flags, void *data) |
dir | 787 | arch/sparc/kernel/sys_sunos.c | error = sunos_nfs_mount (dir, flags, data); |
dir | 797 | arch/sparc/kernel/sys_sunos.c | error = sys_mount(dev_fname, dir, type, linux_flags, NULL); |
dir | 82 | arch/sparc/mm/generic.c | pgd_t * dir; |
dir | 88 | arch/sparc/mm/generic.c | dir = pgd_offset(current->mm, from); |
dir | 91 | arch/sparc/mm/generic.c | pmd_t *pmd = pmd_alloc(dir, from); |
dir | 99 | arch/sparc/mm/generic.c | dir++; |
dir | 224 | arch/sparc/mm/srmmu.c | static pmd_t *srmmu_pmd_offset(pgd_t * dir, unsigned long address) |
dir | 226 | arch/sparc/mm/srmmu.c | return (pmd_t *) srmmu_pgd_page(*dir) + ((address >> SRMMU_PMD_SHIFT) & (SRMMU_PTRS_PER_PMD - 1)); |
dir | 230 | arch/sparc/mm/srmmu.c | static pte_t *srmmu_pte_offset(pmd_t * dir, unsigned long address) |
dir | 232 | arch/sparc/mm/srmmu.c | return (pte_t *) srmmu_pmd_page(*dir) + ((address >> PAGE_SHIFT) & (SRMMU_PTRS_PER_PTE - 1)); |
dir | 1505 | arch/sparc/mm/srmmu.c | static inline pmd_t *srmmu_early_pmd_offset(pgd_t *dir, unsigned long address) |
dir | 1507 | arch/sparc/mm/srmmu.c | return (pmd_t *) srmmu_early_pgd_page(*dir) + ((address >> SRMMU_PMD_SHIFT) & (SRMMU_PTRS_PER_PMD - 1)); |
dir | 1510 | arch/sparc/mm/srmmu.c | static inline pte_t *srmmu_early_pte_offset(pmd_t *dir, unsigned long address) |
dir | 1512 | arch/sparc/mm/srmmu.c | return (pte_t *) srmmu_early_pmd_page(*dir) + ((address >> PAGE_SHIFT) & (SRMMU_PTRS_PER_PTE - 1)); |
dir | 1390 | arch/sparc/mm/sun4c.c | static pmd_t *sun4c_pmd_offset(pgd_t * dir, unsigned long address) |
dir | 1392 | arch/sparc/mm/sun4c.c | return (pmd_t *) dir; |
dir | 1396 | arch/sparc/mm/sun4c.c | static pte_t *sun4c_pte_offset(pmd_t * dir, unsigned long address) |
dir | 1398 | arch/sparc/mm/sun4c.c | return (pte_t *) sun4c_pmd_page(*dir) + ((address >> PAGE_SHIFT) & (SUN4C_PTRS_PER_PTE - 1)); |
dir | 1108 | drivers/char/ftape/fdc-io.c | fdc.dir = fdc.ccr = fdc_base + 7; |
dir | 100 | drivers/char/ftape/fdc-io.h | unsigned short dir; /* Digital Input Register */ |
dir | 146 | drivers/scsi/AM53C974.c | static __inline__ void AM53C974_transfer_dma(struct Scsi_Host *instance, short dir, |
dir | 1996 | drivers/scsi/AM53C974.c | static __inline__ void AM53C974_transfer_dma(struct Scsi_Host *instance, short dir, |
dir | 2003 | drivers/scsi/AM53C974.c | AM53C974_write_8(DMACMD, (dir << 7) | DMACMD_INTE_D); /* idle command */ |
dir | 2010 | drivers/scsi/AM53C974.c | AM53C974_write_8(DMACMD, (dir << 7) | DMACMD_INTE_D | DMACMD_START); |
dir | 2031 | drivers/scsi/AM53C974.c | int dir = statreg & STATREG_IO; |
dir | 2045 | drivers/scsi/AM53C974.c | AM53C974_write_8(DMACMD, ((dir << 7) & DMACMD_DIR) | DMACMD_BLAST); |
dir | 358 | drivers/scsi/aha1740.c | ecb[ecbno].dir= direction; |
dir | 125 | drivers/scsi/aha1740.h | dir:1, /* Direction of transfer 1 = datain */ |
dir | 925 | drivers/scsi/atari_scsi.c | unsigned long count, int dir ) |
dir | 931 | drivers/scsi/atari_scsi.c | instance->host_no, data, addr, count, dir); |
dir | 940 | drivers/scsi/atari_scsi.c | if (dir) |
dir | 958 | drivers/scsi/atari_scsi.c | dma_cache_maintenance( addr, count, dir ); |
dir | 964 | drivers/scsi/atari_scsi.c | tt_scsi_dma.dma_ctrl = dir; |
dir | 967 | drivers/scsi/atari_scsi.c | tt_scsi_dma.dma_ctrl = dir | 2; |
dir | 975 | drivers/scsi/atari_scsi.c | dir <<= 8; |
dir | 976 | drivers/scsi/atari_scsi.c | st_dma.dma_mode_status = 0x90 | dir; |
dir | 977 | drivers/scsi/atari_scsi.c | st_dma.dma_mode_status = 0x90 | (dir ^ 0x100); |
dir | 978 | drivers/scsi/atari_scsi.c | st_dma.dma_mode_status = 0x90 | dir; |
dir | 982 | drivers/scsi/atari_scsi.c | st_dma.fdc_acces_seccount = (count + (dir ? 511 : 0)) >> 9; |
dir | 984 | drivers/scsi/atari_scsi.c | st_dma.dma_mode_status = 0x10 | dir; |
dir | 252 | drivers/scsi/ppa.c | int dir, cnt, blen, fast, bulk; |
dir | 264 | drivers/scsi/ppa.c | cnt = 0; dir = 0; |
dir | 265 | drivers/scsi/ppa.c | if (r == (char) 0xc0) dir = 1; /* d0 = read c0 = write f0 = status */ |
dir | 276 | drivers/scsi/ppa.c | if (dir) do { |
dir | 60 | fs/affs/inode.c | int affs_parent_ino(struct inode *dir) |
dir | 62 | fs/affs/inode.c | int root_ino = (dir->i_sb->u.affs_sb.s_root_block |
dir | 63 | fs/affs/inode.c | - dir->i_sb->u.affs_sb.s_partition_offset); |
dir | 65 | fs/affs/inode.c | if (!S_ISDIR (dir->i_mode)) { |
dir | 69 | fs/affs/inode.c | if (dir->i_ino == root_ino) |
dir | 71 | fs/affs/inode.c | return dir->u.affs_i.i_parent; |
dir | 72 | fs/affs/namei.c | static struct buffer_head *affs_find_entry(struct inode *dir, |
dir | 81 | fs/affs/namei.c | bh = affs_pread (dir, dir->i_ino, &dir_data); |
dir | 86 | fs/affs/namei.c | *ino = dir->i_ino; |
dir | 90 | fs/affs/namei.c | *ino = affs_parent_ino (dir); |
dir | 93 | fs/affs/namei.c | key = affs_get_key_entry (AFFS_I2BSIZE (dir), dir_data, |
dir | 103 | fs/affs/namei.c | bh = affs_pread (dir, key, &dir_data); |
dir | 106 | fs/affs/namei.c | cnamelen = affs_get_file_name (AFFS_I2BSIZE (dir), |
dir | 110 | fs/affs/namei.c | key = affs_get_fh_hash_link (AFFS_I2BSIZE (dir), dir_data); |
dir | 118 | fs/affs/namei.c | int affs_lookup(struct inode * dir,const char * name, int len, |
dir | 125 | fs/affs/namei.c | if (!dir) |
dir | 129 | fs/affs/namei.c | printk ("lookup: %d %d\n", dir->i_ino, len); |
dir | 132 | fs/affs/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 133 | fs/affs/namei.c | iput(dir); |
dir | 136 | fs/affs/namei.c | if (!(bh = affs_find_entry(dir, name, len, &ino))) { |
dir | 137 | fs/affs/namei.c | iput(dir); |
dir | 141 | fs/affs/namei.c | if (!(*result = iget(dir->i_sb, ino))) { |
dir | 142 | fs/affs/namei.c | iput(dir); |
dir | 145 | fs/affs/namei.c | iput (dir); |
dir | 152 | fs/affs/namei.c | if (dir->i_dev == cache.dev && |
dir | 153 | fs/affs/namei.c | dir->i_ino == cache.dir && |
dir | 158 | fs/affs/namei.c | ino_back = dir->i_ino; |
dir | 168 | fs/affs/namei.c | if (!(bh = affs_find_entry(dir,name,len, &ino, &ino_back))) { |
dir | 169 | fs/affs/namei.c | iput(dir); |
dir | 175 | fs/affs/namei.c | if (!(*result = iget(dir->i_sb,ino))) { |
dir | 176 | fs/affs/namei.c | iput(dir); |
dir | 184 | fs/affs/namei.c | iput(dir); |
dir | 50 | fs/affs/symlink.c | static int affs_follow_link(struct inode * dir, struct inode * inode, |
dir | 58 | fs/affs/symlink.c | if (!dir) { |
dir | 59 | fs/affs/symlink.c | dir = current->fs->root; |
dir | 60 | fs/affs/symlink.c | dir->i_count++; |
dir | 63 | fs/affs/symlink.c | iput(dir); |
dir | 68 | fs/affs/symlink.c | iput(dir); |
dir | 73 | fs/affs/symlink.c | iput(dir); |
dir | 86 | fs/affs/symlink.c | error = open_namei(pnt,flag,mode,res_inode,dir); |
dir | 43 | fs/dcache.c | unsigned long dir; |
dir | 73 | fs/dcache.c | #define hash_fn(dev,dir,namehash) ((HASHDEV(dev) ^ (dir) ^ (namehash)) % DCACHE_HASH_QUEUES) |
dir | 144 | fs/dcache.c | static inline struct dir_cache_entry * find_entry(struct inode * dir, const char * name, int len, struct hash_list * hash) |
dir | 149 | fs/dcache.c | if (de->dc_dev != dir->i_dev) |
dir | 151 | fs/dcache.c | if (de->dir != dir->i_ino) |
dir | 153 | fs/dcache.c | if (de->version != dir->i_version) |
dir | 183 | fs/dcache.c | int dcache_lookup(struct inode * dir, const char * name, int len, unsigned long * ino) |
dir | 190 | fs/dcache.c | hash = hash_table + hash_fn(dir->i_dev, dir->i_ino, namehash(name,len)); |
dir | 191 | fs/dcache.c | de = find_entry(dir, name, len, hash); |
dir | 199 | fs/dcache.c | void dcache_add(struct inode * dir, const char * name, int len, unsigned long ino) |
dir | 206 | fs/dcache.c | hash = hash_table + hash_fn(dir->i_dev, dir->i_ino, namehash(name,len)); |
dir | 207 | fs/dcache.c | if ((de = find_entry(dir, name, len, hash)) != NULL) { |
dir | 215 | fs/dcache.c | de->dc_dev = dir->i_dev; |
dir | 216 | fs/dcache.c | de->dir = dir->i_ino; |
dir | 217 | fs/dcache.c | de->version = dir->i_version; |
dir | 239 | fs/ext/freelists.c | struct inode * ext_new_inode(const struct inode * dir) |
dir | 247 | fs/ext/freelists.c | if (!dir || !(inode=get_empty_inode())) |
dir | 249 | fs/ext/freelists.c | sb = dir->i_sb; |
dir | 286 | fs/ext/freelists.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
dir | 79 | fs/ext/namei.c | static struct buffer_head * ext_find_entry(struct inode * dir, |
dir | 88 | fs/ext/namei.c | if (!dir) |
dir | 97 | fs/ext/namei.c | bh = ext_bread(dir,0,0); |
dir | 106 | fs/ext/namei.c | while (offset < dir->i_size) { |
dir | 110 | fs/ext/namei.c | bh = ext_bread(dir,offset>>BLOCK_SIZE_BITS,0); |
dir | 123 | fs/ext/namei.c | kdevname(dir->i_dev), dir->i_ino, offset, |
dir | 134 | fs/ext/namei.c | if (offset + de->rec_len < dir->i_size && |
dir | 151 | fs/ext/namei.c | int ext_lookup(struct inode * dir,const char * name, int len, |
dir | 159 | fs/ext/namei.c | if (!dir) |
dir | 161 | fs/ext/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 162 | fs/ext/namei.c | iput(dir); |
dir | 165 | fs/ext/namei.c | if (!(bh = ext_find_entry(dir,name,len,&de,NULL,NULL))) { |
dir | 166 | fs/ext/namei.c | iput(dir); |
dir | 171 | fs/ext/namei.c | if (!(*result = iget(dir->i_sb,ino))) { |
dir | 172 | fs/ext/namei.c | iput(dir); |
dir | 175 | fs/ext/namei.c | iput(dir); |
dir | 189 | fs/ext/namei.c | static struct buffer_head * ext_add_entry(struct inode * dir, |
dir | 199 | fs/ext/namei.c | if (!dir) |
dir | 210 | fs/ext/namei.c | bh = ext_bread(dir,0,0); |
dir | 217 | fs/ext/namei.c | if ((char *)de >= BLOCK_SIZE+bh->b_data && offset < dir->i_size) { |
dir | 223 | fs/ext/namei.c | bh = ext_bread(dir,offset>>BLOCK_SIZE_BITS,0); |
dir | 228 | fs/ext/namei.c | if (offset >= dir->i_size) { |
dir | 241 | fs/ext/namei.c | dir->i_size += de->rec_len; |
dir | 242 | fs/ext/namei.c | dir->i_dirt = 1; |
dir | 244 | fs/ext/namei.c | dir->i_ctime = CURRENT_TIME; |
dir | 253 | fs/ext/namei.c | bh = ext_bread(dir,offset>>BLOCK_SIZE_BITS,1); |
dir | 261 | fs/ext/namei.c | dir->i_size += de->rec_len; |
dir | 262 | fs/ext/namei.c | dir->i_dirt = 1; |
dir | 264 | fs/ext/namei.c | dir->i_ctime = CURRENT_TIME; |
dir | 273 | fs/ext/namei.c | kdevname(dir->i_dev), dir->i_ino, offset, |
dir | 291 | fs/ext/namei.c | dir->i_mtime = dir->i_ctime = CURRENT_TIME; |
dir | 292 | fs/ext/namei.c | dir->i_dirt = 1; |
dir | 307 | fs/ext/namei.c | int ext_create(struct inode * dir,const char * name, int len, int mode, |
dir | 315 | fs/ext/namei.c | if (!dir) |
dir | 317 | fs/ext/namei.c | inode = ext_new_inode(dir); |
dir | 319 | fs/ext/namei.c | iput(dir); |
dir | 325 | fs/ext/namei.c | bh = ext_add_entry(dir,name,len,&de); |
dir | 330 | fs/ext/namei.c | iput(dir); |
dir | 336 | fs/ext/namei.c | iput(dir); |
dir | 341 | fs/ext/namei.c | int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
dir | 347 | fs/ext/namei.c | if (!dir) |
dir | 349 | fs/ext/namei.c | bh = ext_find_entry(dir,name,len,&de,NULL,NULL); |
dir | 352 | fs/ext/namei.c | iput(dir); |
dir | 355 | fs/ext/namei.c | inode = ext_new_inode(dir); |
dir | 357 | fs/ext/namei.c | iput(dir); |
dir | 367 | fs/ext/namei.c | if (dir->i_mode & S_ISGID) |
dir | 384 | fs/ext/namei.c | bh = ext_add_entry(dir,name,len,&de); |
dir | 389 | fs/ext/namei.c | iput(dir); |
dir | 395 | fs/ext/namei.c | iput(dir); |
dir | 400 | fs/ext/namei.c | int ext_mkdir(struct inode * dir, const char * name, int len, int mode) |
dir | 406 | fs/ext/namei.c | bh = ext_find_entry(dir,name,len,&de,NULL,NULL); |
dir | 409 | fs/ext/namei.c | iput(dir); |
dir | 412 | fs/ext/namei.c | inode = ext_new_inode(dir); |
dir | 414 | fs/ext/namei.c | iput(dir); |
dir | 428 | fs/ext/namei.c | iput(dir); |
dir | 440 | fs/ext/namei.c | de->inode = dir->i_ino; |
dir | 448 | fs/ext/namei.c | if (dir->i_mode & S_ISGID) |
dir | 451 | fs/ext/namei.c | bh = ext_add_entry(dir,name,len,&de); |
dir | 453 | fs/ext/namei.c | iput(dir); |
dir | 460 | fs/ext/namei.c | dir->i_nlink++; |
dir | 461 | fs/ext/namei.c | dir->i_dirt = 1; |
dir | 462 | fs/ext/namei.c | iput(dir); |
dir | 532 | fs/ext/namei.c | int ext_rmdir(struct inode * dir, const char * name, int len) |
dir | 540 | fs/ext/namei.c | bh = ext_find_entry(dir,name,len,&de,&pde,&nde); |
dir | 545 | fs/ext/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
dir | 547 | fs/ext/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 549 | fs/ext/namei.c | current->fsuid != dir->i_uid) |
dir | 551 | fs/ext/namei.c | if (inode->i_dev != dir->i_dev) |
dir | 553 | fs/ext/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
dir | 575 | fs/ext/namei.c | dir->i_nlink--; |
dir | 576 | fs/ext/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 577 | fs/ext/namei.c | dir->i_dirt=1; |
dir | 580 | fs/ext/namei.c | iput(dir); |
dir | 586 | fs/ext/namei.c | int ext_unlink(struct inode * dir, const char * name, int len) |
dir | 595 | fs/ext/namei.c | bh = ext_find_entry(dir,name,len,&de,&pde,&nde); |
dir | 598 | fs/ext/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
dir | 601 | fs/ext/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 603 | fs/ext/namei.c | current->fsuid != dir->i_uid) |
dir | 620 | fs/ext/namei.c | dir->i_ctime = dir->i_mtime = inode->i_ctime; |
dir | 621 | fs/ext/namei.c | dir->i_dirt = 1; |
dir | 626 | fs/ext/namei.c | iput(dir); |
dir | 630 | fs/ext/namei.c | int ext_symlink(struct inode * dir, const char * name, int len, const char * symname) |
dir | 638 | fs/ext/namei.c | if (!(inode = ext_new_inode(dir))) { |
dir | 639 | fs/ext/namei.c | iput(dir); |
dir | 646 | fs/ext/namei.c | iput(dir); |
dir | 660 | fs/ext/namei.c | bh = ext_find_entry(dir,name,len,&de,NULL,NULL); |
dir | 666 | fs/ext/namei.c | iput(dir); |
dir | 669 | fs/ext/namei.c | bh = ext_add_entry(dir,name,len,&de); |
dir | 674 | fs/ext/namei.c | iput(dir); |
dir | 680 | fs/ext/namei.c | iput(dir); |
dir | 685 | fs/ext/namei.c | int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
dir | 692 | fs/ext/namei.c | iput(dir); |
dir | 697 | fs/ext/namei.c | iput(dir); |
dir | 700 | fs/ext/namei.c | bh = ext_find_entry(dir,name,len,&de,NULL,NULL); |
dir | 703 | fs/ext/namei.c | iput(dir); |
dir | 707 | fs/ext/namei.c | bh = ext_add_entry(dir,name,len,&de); |
dir | 709 | fs/ext/namei.c | iput(dir); |
dir | 716 | fs/ext/namei.c | iput(dir); |
dir | 49 | fs/ext/symlink.c | static int ext_follow_link(struct inode * dir, struct inode * inode, |
dir | 56 | fs/ext/symlink.c | if (!dir) { |
dir | 57 | fs/ext/symlink.c | dir = current->fs->root; |
dir | 58 | fs/ext/symlink.c | dir->i_count++; |
dir | 61 | fs/ext/symlink.c | iput(dir); |
dir | 65 | fs/ext/symlink.c | iput(dir); |
dir | 70 | fs/ext/symlink.c | iput(dir); |
dir | 76 | fs/ext/symlink.c | iput(dir); |
dir | 81 | fs/ext/symlink.c | error = open_namei(bh->b_data,flag,mode,res_inode,dir); |
dir | 74 | fs/ext2/dir.c | int ext2_check_dir_entry (const char * function, struct inode * dir, |
dir | 86 | fs/ext2/dir.c | else if (dir && ((char *) de - bh->b_data) + de->rec_len > |
dir | 87 | fs/ext2/dir.c | dir->i_sb->s_blocksize) |
dir | 89 | fs/ext2/dir.c | else if (dir && de->inode > dir->i_sb->u.ext2_sb.s_es->s_inodes_count) |
dir | 93 | fs/ext2/dir.c | ext2_error (dir->i_sb, function, "bad entry in directory #%lu: %s - " |
dir | 95 | fs/ext2/dir.c | dir->i_ino, error_msg, offset, (unsigned long) de->inode, |
dir | 308 | fs/ext2/ialloc.c | struct inode * ext2_new_inode (const struct inode * dir, int mode, int * err) |
dir | 320 | fs/ext2/ialloc.c | if (!dir || !(inode = get_empty_inode ())) |
dir | 322 | fs/ext2/ialloc.c | sb = dir->i_sb; |
dir | 367 | fs/ext2/ialloc.c | i = dir->u.ext2_i.i_block_group; |
dir | 392 | fs/ext2/ialloc.c | i = dir->u.ext2_i.i_block_group + 1; |
dir | 459 | fs/ext2/ialloc.c | inode->i_gid = dir->i_gid; |
dir | 460 | fs/ext2/ialloc.c | else if (dir->i_mode & S_ISGID) { |
dir | 461 | fs/ext2/ialloc.c | inode->i_gid = dir->i_gid; |
dir | 471 | fs/ext2/ialloc.c | inode->u.ext2_i.i_flags = dir->u.ext2_i.i_flags; |
dir | 68 | fs/ext2/namei.c | static struct buffer_head * ext2_find_entry (struct inode * dir, |
dir | 79 | fs/ext2/namei.c | if (!dir) |
dir | 81 | fs/ext2/namei.c | sb = dir->i_sb; |
dir | 96 | fs/ext2/namei.c | if ((block << EXT2_BLOCK_SIZE_BITS (sb)) >= dir->i_size) |
dir | 98 | fs/ext2/namei.c | bh = ext2_getblk (dir, block, 0, &err); |
dir | 104 | fs/ext2/namei.c | for (block = 0, offset = 0; offset < dir->i_size; block++) { |
dir | 117 | fs/ext2/namei.c | dir->i_ino, offset); |
dir | 132 | fs/ext2/namei.c | if (!ext2_check_dir_entry ("ext2_find_entry", dir, |
dir | 150 | fs/ext2/namei.c | dir->i_size) |
dir | 153 | fs/ext2/namei.c | bh = ext2_getblk (dir, block + NAMEI_RA_SIZE, 0, &err); |
dir | 165 | fs/ext2/namei.c | int ext2_lookup (struct inode * dir, const char * name, int len, |
dir | 173 | fs/ext2/namei.c | if (!dir) |
dir | 175 | fs/ext2/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 176 | fs/ext2/namei.c | iput (dir); |
dir | 179 | fs/ext2/namei.c | if (dcache_lookup(dir, name, len, &ino)) { |
dir | 181 | fs/ext2/namei.c | iput(dir); |
dir | 184 | fs/ext2/namei.c | if (!(*result = iget (dir->i_sb, ino))) { |
dir | 185 | fs/ext2/namei.c | iput (dir); |
dir | 188 | fs/ext2/namei.c | iput (dir); |
dir | 191 | fs/ext2/namei.c | ino = dir->i_version; |
dir | 192 | fs/ext2/namei.c | if (!(bh = ext2_find_entry (dir, name, len, &de))) { |
dir | 193 | fs/ext2/namei.c | if (ino == dir->i_version) |
dir | 194 | fs/ext2/namei.c | dcache_add(dir, name, len, 0); |
dir | 195 | fs/ext2/namei.c | iput (dir); |
dir | 199 | fs/ext2/namei.c | dcache_add(dir, name, len, ino); |
dir | 201 | fs/ext2/namei.c | if (!(*result = iget (dir->i_sb, ino))) { |
dir | 202 | fs/ext2/namei.c | iput (dir); |
dir | 205 | fs/ext2/namei.c | iput (dir); |
dir | 219 | fs/ext2/namei.c | static struct buffer_head * ext2_add_entry (struct inode * dir, |
dir | 232 | fs/ext2/namei.c | if (!dir) |
dir | 234 | fs/ext2/namei.c | sb = dir->i_sb; |
dir | 247 | fs/ext2/namei.c | if (dir->i_size == 0) |
dir | 252 | fs/ext2/namei.c | bh = ext2_bread (dir, 0, 0, err); |
dir | 263 | fs/ext2/namei.c | bh = ext2_bread (dir, offset >> EXT2_BLOCK_SIZE_BITS(sb), 1, err); |
dir | 266 | fs/ext2/namei.c | if (dir->i_size <= offset) { |
dir | 267 | fs/ext2/namei.c | if (dir->i_size == 0) { |
dir | 277 | fs/ext2/namei.c | dir->i_size = offset + sb->s_blocksize; |
dir | 278 | fs/ext2/namei.c | dir->i_dirt = 1; |
dir | 286 | fs/ext2/namei.c | if (!ext2_check_dir_entry ("ext2_add_entry", dir, de, bh, |
dir | 322 | fs/ext2/namei.c | dir->i_mtime = dir->i_ctime = CURRENT_TIME; |
dir | 323 | fs/ext2/namei.c | dir->i_dirt = 1; |
dir | 324 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 341 | fs/ext2/namei.c | static int ext2_delete_entry (struct ext2_dir_entry * dir, |
dir | 354 | fs/ext2/namei.c | if (de == dir) { |
dir | 356 | fs/ext2/namei.c | pde->rec_len += dir->rec_len; |
dir | 357 | fs/ext2/namei.c | dir->inode = 0; |
dir | 367 | fs/ext2/namei.c | int ext2_create (struct inode * dir,const char * name, int len, int mode, |
dir | 376 | fs/ext2/namei.c | if (!dir) |
dir | 378 | fs/ext2/namei.c | inode = ext2_new_inode (dir, mode, &err); |
dir | 380 | fs/ext2/namei.c | iput (dir); |
dir | 386 | fs/ext2/namei.c | bh = ext2_add_entry (dir, name, len, &de, &err); |
dir | 391 | fs/ext2/namei.c | iput (dir); |
dir | 395 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 396 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
dir | 398 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 403 | fs/ext2/namei.c | iput (dir); |
dir | 408 | fs/ext2/namei.c | int ext2_mknod (struct inode * dir, const char * name, int len, int mode, |
dir | 416 | fs/ext2/namei.c | if (!dir) |
dir | 418 | fs/ext2/namei.c | bh = ext2_find_entry (dir, name, len, &de); |
dir | 421 | fs/ext2/namei.c | iput (dir); |
dir | 424 | fs/ext2/namei.c | inode = ext2_new_inode (dir, mode, &err); |
dir | 426 | fs/ext2/namei.c | iput (dir); |
dir | 436 | fs/ext2/namei.c | if (dir->i_mode & S_ISGID) |
dir | 450 | fs/ext2/namei.c | bh = ext2_add_entry (dir, name, len, &de, &err); |
dir | 455 | fs/ext2/namei.c | iput (dir); |
dir | 459 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 460 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
dir | 462 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 467 | fs/ext2/namei.c | iput (dir); |
dir | 472 | fs/ext2/namei.c | int ext2_mkdir (struct inode * dir, const char * name, int len, int mode) |
dir | 479 | fs/ext2/namei.c | if (!dir) |
dir | 481 | fs/ext2/namei.c | bh = ext2_find_entry (dir, name, len, &de); |
dir | 484 | fs/ext2/namei.c | iput (dir); |
dir | 487 | fs/ext2/namei.c | if (dir->i_nlink >= EXT2_LINK_MAX) { |
dir | 488 | fs/ext2/namei.c | iput (dir); |
dir | 491 | fs/ext2/namei.c | inode = ext2_new_inode (dir, S_IFDIR, &err); |
dir | 493 | fs/ext2/namei.c | iput (dir); |
dir | 500 | fs/ext2/namei.c | iput (dir); |
dir | 513 | fs/ext2/namei.c | de->inode = dir->i_ino; |
dir | 521 | fs/ext2/namei.c | if (dir->i_mode & S_ISGID) |
dir | 524 | fs/ext2/namei.c | bh = ext2_add_entry (dir, name, len, &de, &err); |
dir | 526 | fs/ext2/namei.c | iput (dir); |
dir | 533 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 534 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
dir | 536 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 540 | fs/ext2/namei.c | dir->i_nlink++; |
dir | 541 | fs/ext2/namei.c | dir->i_dirt = 1; |
dir | 542 | fs/ext2/namei.c | iput (dir); |
dir | 607 | fs/ext2/namei.c | int ext2_rmdir (struct inode * dir, const char * name, int len) |
dir | 615 | fs/ext2/namei.c | if (!dir) |
dir | 618 | fs/ext2/namei.c | bh = ext2_find_entry (dir, name, len, &de); |
dir | 623 | fs/ext2/namei.c | if (!(inode = iget (dir->i_sb, de->inode))) |
dir | 627 | fs/ext2/namei.c | if (inode->i_dev != dir->i_dev) |
dir | 636 | fs/ext2/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 638 | fs/ext2/namei.c | current->fsuid != dir->i_uid) |
dir | 640 | fs/ext2/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
dir | 663 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 669 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 680 | fs/ext2/namei.c | dir->i_nlink--; |
dir | 681 | fs/ext2/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 682 | fs/ext2/namei.c | dir->i_dirt = 1; |
dir | 684 | fs/ext2/namei.c | iput (dir); |
dir | 690 | fs/ext2/namei.c | int ext2_unlink (struct inode * dir, const char * name, int len) |
dir | 698 | fs/ext2/namei.c | if (!dir) |
dir | 702 | fs/ext2/namei.c | bh = ext2_find_entry (dir, name, len, &de); |
dir | 705 | fs/ext2/namei.c | if (!(inode = iget (dir->i_sb, de->inode))) |
dir | 721 | fs/ext2/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 723 | fs/ext2/namei.c | current->fsuid != dir->i_uid) |
dir | 734 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 736 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 740 | fs/ext2/namei.c | dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 741 | fs/ext2/namei.c | dir->i_dirt = 1; |
dir | 744 | fs/ext2/namei.c | inode->i_ctime = dir->i_ctime; |
dir | 749 | fs/ext2/namei.c | iput (dir); |
dir | 753 | fs/ext2/namei.c | int ext2_symlink (struct inode * dir, const char * name, int len, |
dir | 764 | fs/ext2/namei.c | if (!(inode = ext2_new_inode (dir, S_IFLNK, &err))) { |
dir | 765 | fs/ext2/namei.c | iput (dir); |
dir | 779 | fs/ext2/namei.c | iput (dir); |
dir | 803 | fs/ext2/namei.c | bh = ext2_find_entry (dir, name, len, &de); |
dir | 809 | fs/ext2/namei.c | iput (dir); |
dir | 812 | fs/ext2/namei.c | bh = ext2_add_entry (dir, name, len, &de, &err); |
dir | 817 | fs/ext2/namei.c | iput (dir); |
dir | 821 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 822 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
dir | 824 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 829 | fs/ext2/namei.c | iput (dir); |
dir | 834 | fs/ext2/namei.c | int ext2_link (struct inode * oldinode, struct inode * dir, |
dir | 843 | fs/ext2/namei.c | iput (dir); |
dir | 848 | fs/ext2/namei.c | iput (dir); |
dir | 853 | fs/ext2/namei.c | iput (dir); |
dir | 856 | fs/ext2/namei.c | bh = ext2_find_entry (dir, name, len, &de); |
dir | 859 | fs/ext2/namei.c | iput (dir); |
dir | 863 | fs/ext2/namei.c | bh = ext2_add_entry (dir, name, len, &de, &err); |
dir | 865 | fs/ext2/namei.c | iput (dir); |
dir | 870 | fs/ext2/namei.c | dir->i_version = ++event; |
dir | 871 | fs/ext2/namei.c | dcache_add(dir, de->name, de->name_len, de->inode); |
dir | 873 | fs/ext2/namei.c | if (IS_SYNC(dir)) { |
dir | 878 | fs/ext2/namei.c | iput (dir); |
dir | 54 | fs/ext2/symlink.c | static int ext2_follow_link(struct inode * dir, struct inode * inode, |
dir | 62 | fs/ext2/symlink.c | if (!dir) { |
dir | 63 | fs/ext2/symlink.c | dir = current->fs->root; |
dir | 64 | fs/ext2/symlink.c | dir->i_count++; |
dir | 67 | fs/ext2/symlink.c | iput (dir); |
dir | 71 | fs/ext2/symlink.c | iput (dir); |
dir | 76 | fs/ext2/symlink.c | iput (dir); |
dir | 82 | fs/ext2/symlink.c | iput (dir); |
dir | 94 | fs/ext2/symlink.c | error = open_namei (link, flag, mode, res_inode, dir); |
dir | 283 | fs/fat/misc.c | int fat_get_entry(struct inode *dir, loff_t *pos,struct buffer_head **bh, |
dir | 286 | fs/fat/misc.c | struct super_block *sb = dir->i_sb; |
dir | 292 | fs/fat/misc.c | if ((sector = fat_smap(dir,offset >> SECTOR_BITS)) == -1) |
dir | 301 | fs/fat/misc.c | if (!(*bh = breada(dir->i_dev,sector,SECTOR_SIZE,0,FAT_READAHEAD))) { |
dir | 485 | fs/fat/misc.c | int fat_parent_ino(struct inode *dir,int locked) |
dir | 490 | fs/fat/misc.c | if (!S_ISDIR(dir->i_mode)) panic("Non-directory fed to m_p_i"); |
dir | 491 | fs/fat/misc.c | if (dir->i_ino == MSDOS_ROOT_INO) return dir->i_ino; |
dir | 493 | fs/fat/misc.c | if ((curr = raw_scan(dir->i_sb,MSDOS_I(dir)->i_start,MSDOS_DOTDOT, |
dir | 500 | fs/fat/misc.c | if ((prev = raw_scan(dir->i_sb,curr,MSDOS_DOTDOT,&zero,NULL, |
dir | 505 | fs/fat/misc.c | if ((error = raw_scan(dir->i_sb,prev,NULL,&curr,&nr,NULL, |
dir | 521 | fs/fat/misc.c | int fat_subdirs(struct inode *dir) |
dir | 526 | fs/fat/misc.c | if (dir->i_ino == MSDOS_ROOT_INO) |
dir | 527 | fs/fat/misc.c | (void) raw_scan_root(dir->i_sb,NULL,&count,NULL,NULL,NULL,SCAN_ANY); |
dir | 529 | fs/fat/misc.c | if (!MSDOS_I(dir)->i_start) return 0; /* in mkdir */ |
dir | 530 | fs/fat/misc.c | else (void) raw_scan_nonroot(dir->i_sb,MSDOS_I(dir)->i_start, |
dir | 542 | fs/fat/misc.c | int fat_scan(struct inode *dir,const char *name,struct buffer_head **res_bh, |
dir | 548 | fs/fat/misc.c | ? raw_scan(dir->i_sb,MSDOS_I(dir)->i_start, |
dir | 550 | fs/fat/misc.c | : raw_scan(dir->i_sb,MSDOS_I(dir)->i_start, |
dir | 1119 | fs/hpfs/hpfs_fs.c | static int hpfs_lookup(struct inode *dir, const char *name, int len, |
dir | 1130 | fs/hpfs/hpfs_fs.c | if (dir == 0) |
dir | 1132 | fs/hpfs/hpfs_fs.c | if (!S_ISDIR(dir->i_mode)) |
dir | 1141 | fs/hpfs/hpfs_fs.c | de = map_dirent(dir, dir->i_hpfs_dno, "\001\001", 2, &qbh); |
dir | 1143 | fs/hpfs/hpfs_fs.c | de = map_dirent(dir, |
dir | 1144 | fs/hpfs/hpfs_fs.c | fnode_dno(dir->i_dev, dir->i_hpfs_parent_dir), |
dir | 1147 | fs/hpfs/hpfs_fs.c | de = map_dirent(dir, dir->i_hpfs_dno, name, len, &qbh); |
dir | 1169 | fs/hpfs/hpfs_fs.c | if (!(inode = iget(dir->i_sb, ino))) |
dir | 1202 | fs/hpfs/hpfs_fs.c | iput(dir); |
dir | 1211 | fs/hpfs/hpfs_fs.c | iput(dir); |
dir | 61 | fs/isofs/namei.c | static struct buffer_head * isofs_find_entry(struct inode * dir, |
dir | 64 | fs/isofs/namei.c | unsigned long bufsize = ISOFS_BUFFER_SIZE(dir); |
dir | 65 | fs/isofs/namei.c | unsigned char bufbits = ISOFS_BUFFER_BITS(dir); |
dir | 77 | fs/isofs/namei.c | if (!dir) return NULL; |
dir | 79 | fs/isofs/namei.c | if (!(block = dir->u.isofs_i.i_first_extent)) return NULL; |
dir | 84 | fs/isofs/namei.c | block = isofs_bmap(dir,f_pos >> bufbits); |
dir | 86 | fs/isofs/namei.c | if (!block || !(bh = bread(dir->i_dev,block,bufsize))) return NULL; |
dir | 88 | fs/isofs/namei.c | while (f_pos < dir->i_size) { |
dir | 90 | fs/isofs/namei.c | backlink = dir->i_ino; |
dir | 101 | fs/isofs/namei.c | block = isofs_bmap(dir,f_pos>>bufbits); |
dir | 102 | fs/isofs/namei.c | if (!block || !(bh = bread(dir->i_dev,block,bufsize))) |
dir | 123 | fs/isofs/namei.c | block = isofs_bmap(dir,f_pos>>bufbits); |
dir | 124 | fs/isofs/namei.c | if (!block || !(bh = bread(dir->i_dev,block,bufsize))) { |
dir | 134 | fs/isofs/namei.c | inode_number = dir->i_ino; |
dir | 143 | fs/isofs/namei.c | dir->i_sb->s_firstdatazone, |
dir | 144 | fs/isofs/namei.c | dir->i_ino); |
dir | 146 | fs/isofs/namei.c | if((dir->i_sb->u.isofs_sb.s_firstdatazone) != dir->i_ino) |
dir | 147 | fs/isofs/namei.c | inode_number = dir->u.isofs_i.i_backlink; |
dir | 149 | fs/isofs/namei.c | inode_number = dir->i_ino; |
dir | 156 | fs/isofs/namei.c | rrflag = get_rock_ridge_filename(de, &dpnt, &dlen, dir); |
dir | 160 | fs/isofs/namei.c | if(dir->i_sb->u.isofs_sb.s_mapping == 'n') { |
dir | 181 | fs/isofs/namei.c | if( !(de->flags[-dir->i_sb->u.isofs_sb.s_high_sierra] & 5) |
dir | 182 | fs/isofs/namei.c | || dir->i_sb->u.isofs_sb.s_unhide == 'y' ) |
dir | 198 | fs/isofs/namei.c | isofs_lookup_grandparent(dir, |
dir | 199 | fs/isofs/namei.c | find_rock_ridge_relocation(de,dir)); |
dir | 204 | fs/isofs/namei.c | dir->i_ino); |
dir | 220 | fs/isofs/namei.c | int isofs_lookup(struct inode * dir,const char * name, int len, |
dir | 227 | fs/isofs/namei.c | printk("lookup: %x %d\n",dir->i_ino, len); |
dir | 230 | fs/isofs/namei.c | if (!dir) |
dir | 233 | fs/isofs/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 234 | fs/isofs/namei.c | iput(dir); |
dir | 240 | fs/isofs/namei.c | if (dcache_lookup(dir, name, len, &ino)) ino_back = dir->i_ino; |
dir | 247 | fs/isofs/namei.c | if (dir->i_sb->u.isofs_sb.s_name_check == 'r' |
dir | 257 | fs/isofs/namei.c | bh = isofs_find_entry(dir,lcname,len, &ino, &ino_back); |
dir | 260 | fs/isofs/namei.c | bh = isofs_find_entry(dir,name,len, &ino, &ino_back); |
dir | 263 | fs/isofs/namei.c | iput(dir); |
dir | 266 | fs/isofs/namei.c | if (ino_back == dir->i_ino) |
dir | 267 | fs/isofs/namei.c | dcache_add(dir, name, len, ino); |
dir | 271 | fs/isofs/namei.c | if (!(*result = iget(dir->i_sb,ino))) { |
dir | 272 | fs/isofs/namei.c | iput(dir); |
dir | 282 | fs/isofs/namei.c | if (ino_back && !(*result)->i_pipe && (*result)->i_sb == dir->i_sb) { |
dir | 286 | fs/isofs/namei.c | iput(dir); |
dir | 47 | fs/isofs/symlink.c | static int isofs_follow_link(struct inode * dir, struct inode * inode, |
dir | 53 | fs/isofs/symlink.c | if (!dir) { |
dir | 54 | fs/isofs/symlink.c | dir = current->fs->root; |
dir | 55 | fs/isofs/symlink.c | dir->i_count++; |
dir | 58 | fs/isofs/symlink.c | iput(dir); |
dir | 63 | fs/isofs/symlink.c | iput(dir); |
dir | 69 | fs/isofs/symlink.c | iput(dir); |
dir | 76 | fs/isofs/symlink.c | error = open_namei(pnt,flag,mode,res_inode,dir); |
dir | 217 | fs/minix/bitmap.c | struct inode * minix_new_inode(const struct inode * dir) |
dir | 224 | fs/minix/bitmap.c | if (!dir || !(inode = get_empty_inode())) |
dir | 226 | fs/minix/bitmap.c | sb = dir->i_sb; |
dir | 253 | fs/minix/bitmap.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
dir | 127 | fs/minix/inode.c | struct inode * dir; |
dir | 133 | fs/minix/inode.c | dir = s->s_mounted; |
dir | 134 | fs/minix/inode.c | if (!S_ISDIR(dir->i_mode)) |
dir | 137 | fs/minix/inode.c | bh = minix_bread(dir, 0, 0); |
dir | 64 | fs/minix/namei.c | static struct buffer_head * minix_find_entry(struct inode * dir, |
dir | 72 | fs/minix/namei.c | if (!dir || !dir->i_sb) |
dir | 74 | fs/minix/namei.c | info = &dir->i_sb->u.minix_sb; |
dir | 84 | fs/minix/namei.c | while (block*BLOCK_SIZE+offset < dir->i_size) { |
dir | 86 | fs/minix/namei.c | bh = minix_bread(dir,block,0); |
dir | 107 | fs/minix/namei.c | int minix_lookup(struct inode * dir,const char * name, int len, |
dir | 115 | fs/minix/namei.c | if (!dir) |
dir | 117 | fs/minix/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 118 | fs/minix/namei.c | iput(dir); |
dir | 121 | fs/minix/namei.c | if (!(bh = minix_find_entry(dir,name,len,&de))) { |
dir | 122 | fs/minix/namei.c | iput(dir); |
dir | 127 | fs/minix/namei.c | if (!(*result = iget(dir->i_sb,ino))) { |
dir | 128 | fs/minix/namei.c | iput(dir); |
dir | 131 | fs/minix/namei.c | iput(dir); |
dir | 145 | fs/minix/namei.c | static int minix_add_entry(struct inode * dir, |
dir | 158 | fs/minix/namei.c | if (!dir || !dir->i_sb) |
dir | 160 | fs/minix/namei.c | info = &dir->i_sb->u.minix_sb; |
dir | 174 | fs/minix/namei.c | bh = minix_bread(dir,block,1); |
dir | 180 | fs/minix/namei.c | if (block*bh->b_size + offset > dir->i_size) { |
dir | 182 | fs/minix/namei.c | dir->i_size = block*bh->b_size + offset; |
dir | 183 | fs/minix/namei.c | dir->i_dirt = 1; |
dir | 191 | fs/minix/namei.c | dir->i_mtime = dir->i_ctime = CURRENT_TIME; |
dir | 192 | fs/minix/namei.c | dir->i_dirt = 1; |
dir | 195 | fs/minix/namei.c | dir->i_version = ++event; |
dir | 211 | fs/minix/namei.c | int minix_create(struct inode * dir,const char * name, int len, int mode, |
dir | 220 | fs/minix/namei.c | if (!dir) |
dir | 222 | fs/minix/namei.c | inode = minix_new_inode(dir); |
dir | 224 | fs/minix/namei.c | iput(dir); |
dir | 230 | fs/minix/namei.c | error = minix_add_entry(dir,name,len, &bh ,&de); |
dir | 235 | fs/minix/namei.c | iput(dir); |
dir | 241 | fs/minix/namei.c | iput(dir); |
dir | 246 | fs/minix/namei.c | int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
dir | 253 | fs/minix/namei.c | if (!dir) |
dir | 255 | fs/minix/namei.c | bh = minix_find_entry(dir,name,len,&de); |
dir | 258 | fs/minix/namei.c | iput(dir); |
dir | 261 | fs/minix/namei.c | inode = minix_new_inode(dir); |
dir | 263 | fs/minix/namei.c | iput(dir); |
dir | 273 | fs/minix/namei.c | if (dir->i_mode & S_ISGID) |
dir | 287 | fs/minix/namei.c | error = minix_add_entry(dir, name, len, &bh, &de); |
dir | 292 | fs/minix/namei.c | iput(dir); |
dir | 298 | fs/minix/namei.c | iput(dir); |
dir | 303 | fs/minix/namei.c | int minix_mkdir(struct inode * dir, const char * name, int len, int mode) |
dir | 311 | fs/minix/namei.c | if (!dir || !dir->i_sb) { |
dir | 312 | fs/minix/namei.c | iput(dir); |
dir | 315 | fs/minix/namei.c | info = &dir->i_sb->u.minix_sb; |
dir | 316 | fs/minix/namei.c | bh = minix_find_entry(dir,name,len,&de); |
dir | 319 | fs/minix/namei.c | iput(dir); |
dir | 322 | fs/minix/namei.c | if (dir->i_nlink >= MINIX_LINK_MAX) { |
dir | 323 | fs/minix/namei.c | iput(dir); |
dir | 326 | fs/minix/namei.c | inode = minix_new_inode(dir); |
dir | 328 | fs/minix/namei.c | iput(dir); |
dir | 335 | fs/minix/namei.c | iput(dir); |
dir | 345 | fs/minix/namei.c | de->inode = dir->i_ino; |
dir | 351 | fs/minix/namei.c | if (dir->i_mode & S_ISGID) |
dir | 354 | fs/minix/namei.c | error = minix_add_entry(dir, name, len, &bh, &de); |
dir | 356 | fs/minix/namei.c | iput(dir); |
dir | 363 | fs/minix/namei.c | dir->i_nlink++; |
dir | 364 | fs/minix/namei.c | dir->i_dirt = 1; |
dir | 365 | fs/minix/namei.c | iput(dir); |
dir | 430 | fs/minix/namei.c | int minix_rmdir(struct inode * dir, const char * name, int len) |
dir | 438 | fs/minix/namei.c | bh = minix_find_entry(dir,name,len,&de); |
dir | 443 | fs/minix/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
dir | 445 | fs/minix/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 447 | fs/minix/namei.c | current->fsuid != dir->i_uid) |
dir | 449 | fs/minix/namei.c | if (inode->i_dev != dir->i_dev) |
dir | 451 | fs/minix/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
dir | 472 | fs/minix/namei.c | dir->i_version = ++event; |
dir | 476 | fs/minix/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 477 | fs/minix/namei.c | dir->i_nlink--; |
dir | 478 | fs/minix/namei.c | dir->i_dirt=1; |
dir | 481 | fs/minix/namei.c | iput(dir); |
dir | 487 | fs/minix/namei.c | int minix_unlink(struct inode * dir, const char * name, int len) |
dir | 497 | fs/minix/namei.c | bh = minix_find_entry(dir,name,len,&de); |
dir | 500 | fs/minix/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
dir | 512 | fs/minix/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 514 | fs/minix/namei.c | current->fsuid != dir->i_uid) |
dir | 527 | fs/minix/namei.c | dir->i_version = ++event; |
dir | 529 | fs/minix/namei.c | dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 530 | fs/minix/namei.c | dir->i_dirt = 1; |
dir | 532 | fs/minix/namei.c | inode->i_ctime = dir->i_ctime; |
dir | 538 | fs/minix/namei.c | iput(dir); |
dir | 542 | fs/minix/namei.c | int minix_symlink(struct inode * dir, const char * name, int len, const char * symname) |
dir | 550 | fs/minix/namei.c | if (!(inode = minix_new_inode(dir))) { |
dir | 551 | fs/minix/namei.c | iput(dir); |
dir | 558 | fs/minix/namei.c | iput(dir); |
dir | 572 | fs/minix/namei.c | bh = minix_find_entry(dir,name,len,&de); |
dir | 578 | fs/minix/namei.c | iput(dir); |
dir | 581 | fs/minix/namei.c | i = minix_add_entry(dir, name, len, &bh, &de); |
dir | 586 | fs/minix/namei.c | iput(dir); |
dir | 592 | fs/minix/namei.c | iput(dir); |
dir | 597 | fs/minix/namei.c | int minix_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
dir | 605 | fs/minix/namei.c | iput(dir); |
dir | 610 | fs/minix/namei.c | iput(dir); |
dir | 613 | fs/minix/namei.c | bh = minix_find_entry(dir,name,len,&de); |
dir | 616 | fs/minix/namei.c | iput(dir); |
dir | 620 | fs/minix/namei.c | error = minix_add_entry(dir, name, len, &bh, &de); |
dir | 622 | fs/minix/namei.c | iput(dir); |
dir | 629 | fs/minix/namei.c | iput(dir); |
dir | 43 | fs/minix/symlink.c | static int minix_follow_link(struct inode * dir, struct inode * inode, |
dir | 50 | fs/minix/symlink.c | if (!dir) { |
dir | 51 | fs/minix/symlink.c | dir = current->fs->root; |
dir | 52 | fs/minix/symlink.c | dir->i_count++; |
dir | 55 | fs/minix/symlink.c | iput(dir); |
dir | 59 | fs/minix/symlink.c | iput(dir); |
dir | 65 | fs/minix/symlink.c | iput(dir); |
dir | 70 | fs/minix/symlink.c | iput(dir); |
dir | 75 | fs/minix/symlink.c | error = open_namei(bh->b_data,flag,mode,res_inode,dir); |
dir | 149 | fs/msdos/namei.c | static int msdos_find(struct inode *dir,const char *name,int len, |
dir | 157 | fs/msdos/namei.c | dotsOK = MSDOS_SB(dir->i_sb)->options.dotsOK; |
dir | 158 | fs/msdos/namei.c | res = msdos_format_name(MSDOS_SB(dir->i_sb)->options.name_check, |
dir | 172 | fs/msdos/namei.c | return fat_scan(dir,msdos_name,bh,de,ino,scantype); |
dir | 176 | fs/msdos/namei.c | int msdos_lookup(struct inode *dir,const char *name,int len, |
dir | 179 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 188 | fs/msdos/namei.c | if (!dir) return -ENOENT; |
dir | 189 | fs/msdos/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 190 | fs/msdos/namei.c | iput(dir); |
dir | 195 | fs/msdos/namei.c | *result = dir; |
dir | 199 | fs/msdos/namei.c | ino = fat_parent_ino(dir,0); |
dir | 200 | fs/msdos/namei.c | iput(dir); |
dir | 202 | fs/msdos/namei.c | if (!(*result = iget(dir->i_sb,ino))) return -EACCES; |
dir | 206 | fs/msdos/namei.c | if (dcache_lookup(dir, name, len, (unsigned long *) &ino)) { |
dir | 207 | fs/msdos/namei.c | iput(dir); |
dir | 208 | fs/msdos/namei.c | if (!(*result = iget(dir->i_sb, ino))) |
dir | 214 | fs/msdos/namei.c | if ((res = msdos_find(dir,name,len,&bh,&de,&ino)) < 0) { |
dir | 215 | fs/msdos/namei.c | iput(dir); |
dir | 222 | fs/msdos/namei.c | if (!(*result = iget(dir->i_sb,ino))) { |
dir | 223 | fs/msdos/namei.c | iput(dir); |
dir | 230 | fs/msdos/namei.c | iput(dir); |
dir | 235 | fs/msdos/namei.c | iput(dir); |
dir | 243 | fs/msdos/namei.c | fat_fs_panic(dir->i_sb,"msdos_lookup: Can't happen"); |
dir | 244 | fs/msdos/namei.c | iput(dir); |
dir | 249 | fs/msdos/namei.c | iput(dir); |
dir | 256 | fs/msdos/namei.c | static int msdos_create_entry(struct inode *dir, const char *name,int len, |
dir | 259 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 264 | fs/msdos/namei.c | if ((res = fat_scan(dir,NULL,&bh,&de,&ino,SCAN_ANY)) < 0) { |
dir | 266 | fs/msdos/namei.c | if (dir->i_ino == MSDOS_ROOT_INO) return -ENOSPC; |
dir | 267 | fs/msdos/namei.c | if ((res = fat_add_cluster(dir)) < 0) return res; |
dir | 268 | fs/msdos/namei.c | if ((res = fat_scan(dir,NULL,&bh,&de,&ino,SCAN_ANY)) < 0) return res; |
dir | 273 | fs/msdos/namei.c | dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 274 | fs/msdos/namei.c | dir->i_dirt = 1; |
dir | 280 | fs/msdos/namei.c | fat_date_unix2dos(dir->i_mtime,&de->time,&de->date); |
dir | 283 | fs/msdos/namei.c | if ((*result = iget(dir->i_sb,ino)) != NULL) |
dir | 290 | fs/msdos/namei.c | dcache_add(dir, name, len, ino); |
dir | 295 | fs/msdos/namei.c | int msdos_create(struct inode *dir,const char *name,int len,int mode, |
dir | 298 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 304 | fs/msdos/namei.c | if (!dir) return -ENOENT; |
dir | 305 | fs/msdos/namei.c | if ((res = msdos_format_name(MSDOS_SB(dir->i_sb)->options.name_check, |
dir | 307 | fs/msdos/namei.c | MSDOS_SB(dir->i_sb)->options.dotsOK)) < 0) { |
dir | 308 | fs/msdos/namei.c | iput(dir); |
dir | 317 | fs/msdos/namei.c | if (fat_scan(dir,msdos_name,&bh,&de,&ino,SCAN_HID) >= 0) { |
dir | 320 | fs/msdos/namei.c | iput(dir); |
dir | 323 | fs/msdos/namei.c | if (fat_scan(dir,msdos_name,&bh,&de,&ino,SCAN_NOTHID) >= 0) { |
dir | 326 | fs/msdos/namei.c | iput(dir); |
dir | 329 | fs/msdos/namei.c | res = msdos_create_entry(dir,msdos_name,len,S_ISDIR(mode),is_hid, |
dir | 332 | fs/msdos/namei.c | iput(dir); |
dir | 357 | fs/msdos/namei.c | static int msdos_empty(struct inode *dir) |
dir | 359 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 364 | fs/msdos/namei.c | if (dir->i_count > 1) |
dir | 366 | fs/msdos/namei.c | if (MSDOS_I(dir)->i_start) { /* may be zero in mkdir */ |
dir | 369 | fs/msdos/namei.c | while (fat_get_entry(dir,&pos,&bh,&de) > -1) |
dir | 383 | fs/msdos/namei.c | int msdos_rmdir(struct inode *dir,const char *name,int len) |
dir | 385 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 396 | fs/msdos/namei.c | if ((res = msdos_find(dir,name,len,&bh,&de,&ino)) < 0) goto rmdir_done; |
dir | 398 | fs/msdos/namei.c | if (!(inode = iget(dir->i_sb,ino))) goto rmdir_done; |
dir | 402 | fs/msdos/namei.c | if (dir->i_dev != inode->i_dev || dir == inode) |
dir | 408 | fs/msdos/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 409 | fs/msdos/namei.c | dir->i_nlink--; |
dir | 410 | fs/msdos/namei.c | inode->i_dirt = dir->i_dirt = 1; |
dir | 416 | fs/msdos/namei.c | iput(dir); |
dir | 422 | fs/msdos/namei.c | int msdos_mkdir(struct inode *dir,const char *name,int len,int mode) |
dir | 424 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 431 | fs/msdos/namei.c | if ((res = msdos_format_name(MSDOS_SB(dir->i_sb)->options.name_check, |
dir | 433 | fs/msdos/namei.c | MSDOS_SB(dir->i_sb)->options.dotsOK)) < 0) { |
dir | 434 | fs/msdos/namei.c | iput(dir); |
dir | 439 | fs/msdos/namei.c | if (fat_scan(dir,msdos_name,&bh,&de,&ino,SCAN_ANY) >= 0) { |
dir | 442 | fs/msdos/namei.c | iput(dir); |
dir | 445 | fs/msdos/namei.c | if ((res = msdos_create_entry(dir,msdos_name,len,1,is_hid, |
dir | 448 | fs/msdos/namei.c | iput(dir); |
dir | 451 | fs/msdos/namei.c | dir->i_nlink++; |
dir | 465 | fs/msdos/namei.c | dot->i_size = dir->i_size; |
dir | 466 | fs/msdos/namei.c | MSDOS_I(dot)->i_start = MSDOS_I(dir)->i_start; |
dir | 467 | fs/msdos/namei.c | dot->i_nlink = dir->i_nlink; |
dir | 472 | fs/msdos/namei.c | iput(dir); |
dir | 476 | fs/msdos/namei.c | if (msdos_rmdir(dir,name,len) < 0) |
dir | 477 | fs/msdos/namei.c | fat_fs_panic(dir->i_sb,"rmdir in mkdir failed"); |
dir | 484 | fs/msdos/namei.c | struct inode *dir, |
dir | 489 | fs/msdos/namei.c | struct super_block *sb = dir->i_sb; |
dir | 497 | fs/msdos/namei.c | if ((res = msdos_find(dir,name,len,&bh,&de,&ino)) < 0) |
dir | 499 | fs/msdos/namei.c | if (!(inode = iget(dir->i_sb,ino))) { |
dir | 512 | fs/msdos/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 514 | fs/msdos/namei.c | inode->i_dirt = dir->i_dirt = 1; |
dir | 520 | fs/msdos/namei.c | iput(dir); |
dir | 525 | fs/msdos/namei.c | int msdos_unlink(struct inode *dir,const char *name,int len) |
dir | 527 | fs/msdos/namei.c | return msdos_unlinkx (dir,name,len,1); |
dir | 531 | fs/msdos/namei.c | int msdos_unlink_umsdos(struct inode *dir,const char *name,int len) |
dir | 533 | fs/msdos/namei.c | return msdos_unlinkx (dir,name,len,0); |
dir | 153 | fs/namei.c | int lookup(struct inode * dir,const char * name, int len, |
dir | 160 | fs/namei.c | if (!dir) |
dir | 163 | fs/namei.c | perm = permission(dir,MAY_EXEC); |
dir | 165 | fs/namei.c | if (dir == current->fs->root) { |
dir | 166 | fs/namei.c | *result = dir; |
dir | 168 | fs/namei.c | } else if ((sb = dir->i_sb) && (dir == sb->s_mounted)) { |
dir | 169 | fs/namei.c | iput(dir); |
dir | 170 | fs/namei.c | dir = sb->s_covered; |
dir | 171 | fs/namei.c | if (!dir) |
dir | 173 | fs/namei.c | dir->i_count++; |
dir | 176 | fs/namei.c | if (!dir->i_op || !dir->i_op->lookup) { |
dir | 177 | fs/namei.c | iput(dir); |
dir | 181 | fs/namei.c | iput(dir); |
dir | 185 | fs/namei.c | *result = dir; |
dir | 188 | fs/namei.c | return dir->i_op->lookup(dir, name, len, result); |
dir | 191 | fs/namei.c | int follow_link(struct inode * dir, struct inode * inode, |
dir | 194 | fs/namei.c | if (!dir || !inode) { |
dir | 195 | fs/namei.c | iput(dir); |
dir | 201 | fs/namei.c | iput(dir); |
dir | 205 | fs/namei.c | return inode->i_op->follow_link(dir,inode,flag,mode,res_inode); |
dir | 337 | fs/namei.c | struct inode * dir, *inode; |
dir | 341 | fs/namei.c | error = dir_namei(pathname, &namelen, &basename, base, &dir); |
dir | 346 | fs/namei.c | iput(dir); |
dir | 350 | fs/namei.c | if ((error = permission(dir,ACC_MODE(flag))) != 0) { |
dir | 351 | fs/namei.c | iput(dir); |
dir | 354 | fs/namei.c | *res_inode=dir; |
dir | 357 | fs/namei.c | dir->i_count++; /* lookup eats the dir */ |
dir | 359 | fs/namei.c | down(&dir->i_sem); |
dir | 360 | fs/namei.c | error = lookup(dir, basename, namelen, &inode); |
dir | 366 | fs/namei.c | } else if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) |
dir | 368 | fs/namei.c | else if (!dir->i_op || !dir->i_op->create) |
dir | 370 | fs/namei.c | else if (IS_RDONLY(dir)) |
dir | 373 | fs/namei.c | dir->i_count++; /* create eats the dir */ |
dir | 374 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 375 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 376 | fs/namei.c | error = dir->i_op->create(dir, basename, namelen, mode, res_inode); |
dir | 377 | fs/namei.c | up(&dir->i_sem); |
dir | 378 | fs/namei.c | iput(dir); |
dir | 381 | fs/namei.c | up(&dir->i_sem); |
dir | 383 | fs/namei.c | error = lookup(dir, basename, namelen, &inode); |
dir | 385 | fs/namei.c | iput(dir); |
dir | 388 | fs/namei.c | error = follow_link(dir,inode,flag,mode,&inode); |
dir | 462 | fs/namei.c | struct inode * dir; |
dir | 465 | fs/namei.c | error = dir_namei(filename, &namelen, &basename, NULL, &dir); |
dir | 469 | fs/namei.c | iput(dir); |
dir | 472 | fs/namei.c | if (IS_RDONLY(dir)) { |
dir | 473 | fs/namei.c | iput(dir); |
dir | 476 | fs/namei.c | if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) { |
dir | 477 | fs/namei.c | iput(dir); |
dir | 480 | fs/namei.c | if (!dir->i_op || !dir->i_op->mknod) { |
dir | 481 | fs/namei.c | iput(dir); |
dir | 484 | fs/namei.c | dir->i_count++; |
dir | 485 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 486 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 487 | fs/namei.c | down(&dir->i_sem); |
dir | 488 | fs/namei.c | error = dir->i_op->mknod(dir,basename,namelen,mode,dev); |
dir | 489 | fs/namei.c | up(&dir->i_sem); |
dir | 490 | fs/namei.c | iput(dir); |
dir | 522 | fs/namei.c | struct inode * dir; |
dir | 524 | fs/namei.c | error = dir_namei(pathname, &namelen, &basename, NULL, &dir); |
dir | 528 | fs/namei.c | iput(dir); |
dir | 531 | fs/namei.c | if (IS_RDONLY(dir)) { |
dir | 532 | fs/namei.c | iput(dir); |
dir | 535 | fs/namei.c | if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) { |
dir | 536 | fs/namei.c | iput(dir); |
dir | 539 | fs/namei.c | if (!dir->i_op || !dir->i_op->mkdir) { |
dir | 540 | fs/namei.c | iput(dir); |
dir | 543 | fs/namei.c | dir->i_count++; |
dir | 544 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 545 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 546 | fs/namei.c | down(&dir->i_sem); |
dir | 547 | fs/namei.c | error = dir->i_op->mkdir(dir, basename, namelen, mode & 0777 & ~current->fs->umask); |
dir | 548 | fs/namei.c | up(&dir->i_sem); |
dir | 549 | fs/namei.c | iput(dir); |
dir | 570 | fs/namei.c | struct inode * dir; |
dir | 572 | fs/namei.c | error = dir_namei(name, &namelen, &basename, NULL, &dir); |
dir | 576 | fs/namei.c | iput(dir); |
dir | 579 | fs/namei.c | if (IS_RDONLY(dir)) { |
dir | 580 | fs/namei.c | iput(dir); |
dir | 583 | fs/namei.c | if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) { |
dir | 584 | fs/namei.c | iput(dir); |
dir | 590 | fs/namei.c | if (IS_APPEND(dir)) { |
dir | 591 | fs/namei.c | iput(dir); |
dir | 594 | fs/namei.c | if (!dir->i_op || !dir->i_op->rmdir) { |
dir | 595 | fs/namei.c | iput(dir); |
dir | 598 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 599 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 600 | fs/namei.c | return dir->i_op->rmdir(dir,basename,namelen); |
dir | 620 | fs/namei.c | struct inode * dir; |
dir | 622 | fs/namei.c | error = dir_namei(name, &namelen, &basename, NULL, &dir); |
dir | 626 | fs/namei.c | iput(dir); |
dir | 629 | fs/namei.c | if (IS_RDONLY(dir)) { |
dir | 630 | fs/namei.c | iput(dir); |
dir | 633 | fs/namei.c | if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) { |
dir | 634 | fs/namei.c | iput(dir); |
dir | 640 | fs/namei.c | if (IS_APPEND(dir)) { |
dir | 641 | fs/namei.c | iput(dir); |
dir | 644 | fs/namei.c | if (!dir->i_op || !dir->i_op->unlink) { |
dir | 645 | fs/namei.c | iput(dir); |
dir | 648 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 649 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 650 | fs/namei.c | return dir->i_op->unlink(dir,basename,namelen); |
dir | 668 | fs/namei.c | struct inode * dir; |
dir | 672 | fs/namei.c | error = dir_namei(newname, &namelen, &basename, NULL, &dir); |
dir | 676 | fs/namei.c | iput(dir); |
dir | 679 | fs/namei.c | if (IS_RDONLY(dir)) { |
dir | 680 | fs/namei.c | iput(dir); |
dir | 683 | fs/namei.c | if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) { |
dir | 684 | fs/namei.c | iput(dir); |
dir | 687 | fs/namei.c | if (!dir->i_op || !dir->i_op->symlink) { |
dir | 688 | fs/namei.c | iput(dir); |
dir | 691 | fs/namei.c | dir->i_count++; |
dir | 692 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 693 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 694 | fs/namei.c | down(&dir->i_sem); |
dir | 695 | fs/namei.c | error = dir->i_op->symlink(dir,basename,namelen,oldname); |
dir | 696 | fs/namei.c | up(&dir->i_sem); |
dir | 697 | fs/namei.c | iput(dir); |
dir | 720 | fs/namei.c | struct inode * dir; |
dir | 724 | fs/namei.c | error = dir_namei(newname, &namelen, &basename, NULL, &dir); |
dir | 731 | fs/namei.c | iput(dir); |
dir | 734 | fs/namei.c | if (IS_RDONLY(dir)) { |
dir | 736 | fs/namei.c | iput(dir); |
dir | 739 | fs/namei.c | if (dir->i_dev != oldinode->i_dev) { |
dir | 740 | fs/namei.c | iput(dir); |
dir | 744 | fs/namei.c | if ((error = permission(dir,MAY_WRITE | MAY_EXEC)) != 0) { |
dir | 745 | fs/namei.c | iput(dir); |
dir | 753 | fs/namei.c | iput(dir); |
dir | 757 | fs/namei.c | if (!dir->i_op || !dir->i_op->link) { |
dir | 758 | fs/namei.c | iput(dir); |
dir | 762 | fs/namei.c | dir->i_count++; |
dir | 763 | fs/namei.c | if (dir->i_sb && dir->i_sb->dq_op) |
dir | 764 | fs/namei.c | dir->i_sb->dq_op->initialize(dir, -1); |
dir | 765 | fs/namei.c | down(&dir->i_sem); |
dir | 766 | fs/namei.c | error = dir->i_op->link(oldinode, dir, basename, namelen); |
dir | 767 | fs/namei.c | up(&dir->i_sem); |
dir | 768 | fs/namei.c | iput(dir); |
dir | 37 | fs/ncpfs/dir.c | ncp_do_readdir(struct ncp_server *server, struct inode *dir, int fpos, |
dir | 41 | fs/ncpfs/dir.c | ncp_iget(struct inode *dir, struct nw_file_info *finfo); |
dir | 44 | fs/ncpfs/dir.c | ncp_find_dir_inode(struct inode *dir, const char *name); |
dir | 47 | fs/ncpfs/dir.c | ncp_lookup(struct inode *dir, const char *__name, |
dir | 51 | fs/ncpfs/dir.c | ncp_create(struct inode *dir, const char *name, int len, int mode, |
dir | 55 | fs/ncpfs/dir.c | ncp_mkdir(struct inode *dir, const char *name, int len, int mode); |
dir | 58 | fs/ncpfs/dir.c | ncp_rmdir(struct inode *dir, const char *name, int len); |
dir | 61 | fs/ncpfs/dir.c | ncp_unlink(struct inode *dir, const char *name, int len); |
dir | 219 | fs/ncpfs/dir.c | struct ncp_inode_info *dir = NCP_INOP(inode); |
dir | 254 | fs/ncpfs/dir.c | ncp_info_ino(server, dir)) < 0) |
dir | 264 | fs/ncpfs/dir.c | ncp_info_ino(server, dir->dir)) < 0) |
dir | 454 | fs/ncpfs/dir.c | ncp_do_readdir(struct ncp_server *server, struct inode *dir, int fpos, |
dir | 476 | fs/ncpfs/dir.c | if ((fpos != total_count) || (dir != last_dir)) |
dir | 479 | fs/ncpfs/dir.c | last_dir = dir; |
dir | 482 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir)->entryName); |
dir | 484 | fs/ncpfs/dir.c | if (ncp_initialize_search(server, NCP_ISTRUCT(dir), &seq)!=0) |
dir | 555 | fs/ncpfs/dir.c | ncp_iget(struct inode *dir, struct nw_file_info *finfo) |
dir | 561 | fs/ncpfs/dir.c | if (dir == NULL) |
dir | 585 | fs/ncpfs/dir.c | new_inode_info->dir = NCP_INOP(dir); |
dir | 588 | fs/ncpfs/dir.c | NCP_INOP(dir)->nused += 1; |
dir | 594 | fs/ncpfs/dir.c | root = &(NCP_SERVER(dir)->root); |
dir | 601 | fs/ncpfs/dir.c | if (!(inode = iget(dir->i_sb, ncp_info_ino(NCP_SERVER(dir), |
dir | 623 | fs/ncpfs/dir.c | struct ncp_inode_info *dir = i->dir; |
dir | 633 | fs/ncpfs/dir.c | if (dir == i) return; |
dir | 635 | fs/ncpfs/dir.c | (dir->nused)--; |
dir | 636 | fs/ncpfs/dir.c | i = dir; |
dir | 663 | fs/ncpfs/dir.c | root->dir = root; |
dir | 717 | fs/ncpfs/dir.c | ncp_find_dir_inode(struct inode *dir, const char *name) |
dir | 719 | fs/ncpfs/dir.c | struct ncp_server *server = NCP_SERVER(dir); |
dir | 720 | fs/ncpfs/dir.c | struct nw_info_struct *dir_info = NCP_ISTRUCT(dir); |
dir | 730 | fs/ncpfs/dir.c | if ( (result->dir->finfo.i.DosDirNum == dir_info->DosDirNum) |
dir | 731 | fs/ncpfs/dir.c | && (result->dir->finfo.i.volNumber == dir_info->volNumber) |
dir | 751 | fs/ncpfs/dir.c | ncp_lookup(struct inode *dir, const char *__name, int len, |
dir | 762 | fs/ncpfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) |
dir | 765 | fs/ncpfs/dir.c | iput(dir); |
dir | 769 | fs/ncpfs/dir.c | server = NCP_SERVER(dir); |
dir | 773 | fs/ncpfs/dir.c | iput(dir); |
dir | 782 | fs/ncpfs/dir.c | *result = dir; |
dir | 789 | fs/ncpfs/dir.c | struct ncp_inode_info *parent = NCP_INOP(dir)->dir; |
dir | 796 | fs/ncpfs/dir.c | *result = iget(dir->i_sb, ncp_info_ino(server, parent)); |
dir | 797 | fs/ncpfs/dir.c | iput(dir); |
dir | 810 | fs/ncpfs/dir.c | result_info = ncp_find_dir_inode(dir, name); |
dir | 822 | fs/ncpfs/dir.c | *result = iget(dir->i_sb, ncp_info_ino(server, result_info)); |
dir | 823 | fs/ncpfs/dir.c | iput(dir); |
dir | 839 | fs/ncpfs/dir.c | if ((dir->i_dev == c_dev) && (dir->i_ino == c_ino)) |
dir | 869 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir)->entryName, name); |
dir | 871 | fs/ncpfs/dir.c | if (ncp_is_server_root(dir)) |
dir | 878 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir)->volNumber, |
dir | 879 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir)->DosDirNum, |
dir | 884 | fs/ncpfs/dir.c | iput(dir); |
dir | 892 | fs/ncpfs/dir.c | if (!(*result = ncp_iget(dir, &finfo))) |
dir | 894 | fs/ncpfs/dir.c | iput(dir); |
dir | 898 | fs/ncpfs/dir.c | iput(dir); |
dir | 903 | fs/ncpfs/dir.c | ncp_create(struct inode *dir, const char *name, int len, int mode, |
dir | 911 | fs/ncpfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) |
dir | 914 | fs/ncpfs/dir.c | iput(dir); |
dir | 917 | fs/ncpfs/dir.c | if (!ncp_conn_valid(NCP_SERVER(dir))) |
dir | 919 | fs/ncpfs/dir.c | iput(dir); |
dir | 927 | fs/ncpfs/dir.c | if (ncp_open_create_file_or_subdir(NCP_SERVER(dir), |
dir | 928 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir), _name, |
dir | 934 | fs/ncpfs/dir.c | iput(dir); |
dir | 938 | fs/ncpfs/dir.c | ncp_invalid_dir_cache(dir); |
dir | 943 | fs/ncpfs/dir.c | if (!(*result = ncp_iget(dir, &finfo)) < 0) |
dir | 945 | fs/ncpfs/dir.c | ncp_close_file(NCP_SERVER(dir), finfo.file_handle); |
dir | 946 | fs/ncpfs/dir.c | iput(dir); |
dir | 950 | fs/ncpfs/dir.c | iput(dir); |
dir | 955 | fs/ncpfs/dir.c | ncp_mkdir(struct inode *dir, const char *name, int len, int mode) |
dir | 973 | fs/ncpfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) |
dir | 976 | fs/ncpfs/dir.c | iput(dir); |
dir | 979 | fs/ncpfs/dir.c | if (!ncp_conn_valid(NCP_SERVER(dir))) |
dir | 981 | fs/ncpfs/dir.c | iput(dir); |
dir | 985 | fs/ncpfs/dir.c | if (ncp_open_create_file_or_subdir(NCP_SERVER(dir), |
dir | 986 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir), _name, |
dir | 995 | fs/ncpfs/dir.c | ncp_invalid_dir_cache(dir); |
dir | 998 | fs/ncpfs/dir.c | iput(dir); |
dir | 1003 | fs/ncpfs/dir.c | ncp_rmdir(struct inode *dir, const char *name, int len) |
dir | 1008 | fs/ncpfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) |
dir | 1011 | fs/ncpfs/dir.c | iput(dir); |
dir | 1014 | fs/ncpfs/dir.c | if (!ncp_conn_valid(NCP_SERVER(dir))) |
dir | 1016 | fs/ncpfs/dir.c | iput(dir); |
dir | 1019 | fs/ncpfs/dir.c | if (ncp_find_dir_inode(dir, name) != NULL) |
dir | 1021 | fs/ncpfs/dir.c | iput(dir); |
dir | 1031 | fs/ncpfs/dir.c | if ((error = ncp_del_file_or_subdir(NCP_SERVER(dir), |
dir | 1032 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir), |
dir | 1035 | fs/ncpfs/dir.c | ncp_invalid_dir_cache(dir); |
dir | 1042 | fs/ncpfs/dir.c | iput(dir); |
dir | 1047 | fs/ncpfs/dir.c | ncp_unlink(struct inode *dir, const char *name, int len) |
dir | 1052 | fs/ncpfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) |
dir | 1055 | fs/ncpfs/dir.c | iput(dir); |
dir | 1058 | fs/ncpfs/dir.c | if (!ncp_conn_valid(NCP_SERVER(dir))) |
dir | 1060 | fs/ncpfs/dir.c | iput(dir); |
dir | 1063 | fs/ncpfs/dir.c | if (ncp_find_dir_inode(dir, name) != NULL) |
dir | 1065 | fs/ncpfs/dir.c | iput(dir); |
dir | 1074 | fs/ncpfs/dir.c | if ((error = ncp_del_file_or_subdir(NCP_SERVER(dir), |
dir | 1075 | fs/ncpfs/dir.c | NCP_ISTRUCT(dir), |
dir | 1078 | fs/ncpfs/dir.c | ncp_invalid_dir_cache(dir); |
dir | 1085 | fs/ncpfs/dir.c | iput(dir); |
dir | 244 | fs/ncpfs/file.c | ncp_invalid_dir_cache(NCP_INOP(inode)->dir->inode); |
dir | 517 | fs/ncpfs/inode.c | ncp_invalid_dir_cache(NCP_INOP(inode)->dir->inode); |
dir | 371 | fs/ncpfs/ncplib_kernel.c | struct nw_info_struct *dir, char *name) |
dir | 380 | fs/ncpfs/ncplib_kernel.c | ncp_add_handle_path(server, dir->volNumber, |
dir | 381 | fs/ncpfs/ncplib_kernel.c | dir->DosDirNum, 1, name); |
dir | 401 | fs/ncpfs/ncplib_kernel.c | struct nw_info_struct *dir, char *name, |
dir | 426 | fs/ncpfs/ncplib_kernel.c | if (dir != NULL) |
dir | 428 | fs/ncpfs/ncplib_kernel.c | ncp_add_handle_path(server, dir->volNumber, |
dir | 429 | fs/ncpfs/ncplib_kernel.c | dir->DosDirNum, 1, name); |
dir | 448 | fs/ncpfs/ncplib_kernel.c | if (dir != NULL) |
dir | 463 | fs/ncpfs/ncplib_kernel.c | struct nw_info_struct *dir, |
dir | 472 | fs/ncpfs/ncplib_kernel.c | ncp_add_handle_path(server, dir->volNumber, dir->DosDirNum, 1, NULL); |
dir | 143 | fs/ncpfs/ncplib_kernel.h | struct nw_info_struct *dir, char *name); |
dir | 147 | fs/ncpfs/ncplib_kernel.h | struct nw_info_struct *dir, char *name, |
dir | 155 | fs/ncpfs/ncplib_kernel.h | struct nw_info_struct *dir, |
dir | 70 | fs/nfs/dir.c | static inline void revalidate_dir(struct nfs_server * server, struct inode * dir) |
dir | 74 | fs/nfs/dir.c | if (jiffies - NFS_READTIME(dir) < server->acdirmax) |
dir | 77 | fs/nfs/dir.c | NFS_READTIME(dir) = jiffies; |
dir | 78 | fs/nfs/dir.c | if (nfs_proc_getattr(server, NFS_FH(dir), &fattr) == 0) { |
dir | 79 | fs/nfs/dir.c | nfs_refresh_inode(dir, &fattr); |
dir | 80 | fs/nfs/dir.c | if (fattr.mtime.seconds == NFS_OLDMTIME(dir)) |
dir | 82 | fs/nfs/dir.c | NFS_OLDMTIME(dir) = fattr.mtime.seconds; |
dir | 87 | fs/nfs/dir.c | static int nfs_dir_open(struct inode * dir, struct file * file) |
dir | 89 | fs/nfs/dir.c | revalidate_dir(NFS_SERVER(dir), dir); |
dir | 245 | fs/nfs/dir.c | static struct nfs_lookup_cache_entry *nfs_lookup_cache_index(struct inode *dir, |
dir | 253 | fs/nfs/dir.c | if (entry->dev == dir->i_dev |
dir | 254 | fs/nfs/dir.c | && entry->inode == dir->i_ino |
dir | 261 | fs/nfs/dir.c | static int nfs_lookup_cache_lookup(struct inode *dir, const char *filename, |
dir | 273 | fs/nfs/dir.c | if ((entry = nfs_lookup_cache_index(dir, filename))) { |
dir | 285 | fs/nfs/dir.c | static void nfs_lookup_cache_add(struct inode *dir, const char *filename, |
dir | 296 | fs/nfs/dir.c | if (!(entry = nfs_lookup_cache_index(dir, filename))) { |
dir | 301 | fs/nfs/dir.c | entry->dev = dir->i_dev; |
dir | 302 | fs/nfs/dir.c | entry->inode = dir->i_ino; |
dir | 307 | fs/nfs/dir.c | ? NFS_SERVER(dir)->acdirmin : NFS_SERVER(dir)->acregmin); |
dir | 310 | fs/nfs/dir.c | static void nfs_lookup_cache_remove(struct inode *dir, struct inode *inode, |
dir | 322 | fs/nfs/dir.c | else if ((entry = nfs_lookup_cache_index(dir, filename))) { |
dir | 350 | fs/nfs/dir.c | static int nfs_lookup(struct inode *dir, const char *__name, int len, |
dir | 359 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 361 | fs/nfs/dir.c | iput(dir); |
dir | 365 | fs/nfs/dir.c | iput(dir); |
dir | 371 | fs/nfs/dir.c | *result = dir; |
dir | 374 | fs/nfs/dir.c | if ((NFS_SERVER(dir)->flags & NFS_MOUNT_NOAC) |
dir | 375 | fs/nfs/dir.c | || !nfs_lookup_cache_lookup(dir, name, &fhandle, &fattr)) { |
dir | 376 | fs/nfs/dir.c | if ((error = nfs_proc_lookup(NFS_SERVER(dir), NFS_FH(dir), |
dir | 378 | fs/nfs/dir.c | iput(dir); |
dir | 381 | fs/nfs/dir.c | nfs_lookup_cache_add(dir, name, &fhandle, &fattr); |
dir | 383 | fs/nfs/dir.c | if (!(*result = nfs_fhget(dir->i_sb, &fhandle, &fattr))) { |
dir | 384 | fs/nfs/dir.c | iput(dir); |
dir | 387 | fs/nfs/dir.c | iput(dir); |
dir | 391 | fs/nfs/dir.c | static int nfs_create(struct inode *dir, const char *name, int len, int mode, |
dir | 400 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 402 | fs/nfs/dir.c | iput(dir); |
dir | 406 | fs/nfs/dir.c | iput(dir); |
dir | 412 | fs/nfs/dir.c | if ((error = nfs_proc_create(NFS_SERVER(dir), NFS_FH(dir), |
dir | 414 | fs/nfs/dir.c | iput(dir); |
dir | 417 | fs/nfs/dir.c | if (!(*result = nfs_fhget(dir->i_sb, &fhandle, &fattr))) { |
dir | 418 | fs/nfs/dir.c | iput(dir); |
dir | 421 | fs/nfs/dir.c | nfs_lookup_cache_add(dir, name, &fhandle, &fattr); |
dir | 422 | fs/nfs/dir.c | iput(dir); |
dir | 426 | fs/nfs/dir.c | static int nfs_mknod(struct inode *dir, const char *name, int len, |
dir | 434 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 436 | fs/nfs/dir.c | iput(dir); |
dir | 440 | fs/nfs/dir.c | iput(dir); |
dir | 450 | fs/nfs/dir.c | error = nfs_proc_create(NFS_SERVER(dir), NFS_FH(dir), |
dir | 453 | fs/nfs/dir.c | nfs_lookup_cache_add(dir, name, &fhandle, &fattr); |
dir | 454 | fs/nfs/dir.c | iput(dir); |
dir | 458 | fs/nfs/dir.c | static int nfs_mkdir(struct inode *dir, const char *name, int len, int mode) |
dir | 465 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 467 | fs/nfs/dir.c | iput(dir); |
dir | 471 | fs/nfs/dir.c | iput(dir); |
dir | 477 | fs/nfs/dir.c | error = nfs_proc_mkdir(NFS_SERVER(dir), NFS_FH(dir), |
dir | 480 | fs/nfs/dir.c | nfs_lookup_cache_add(dir, name, &fhandle, &fattr); |
dir | 481 | fs/nfs/dir.c | iput(dir); |
dir | 485 | fs/nfs/dir.c | static int nfs_rmdir(struct inode *dir, const char *name, int len) |
dir | 489 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 491 | fs/nfs/dir.c | iput(dir); |
dir | 495 | fs/nfs/dir.c | iput(dir); |
dir | 498 | fs/nfs/dir.c | error = nfs_proc_rmdir(NFS_SERVER(dir), NFS_FH(dir), name); |
dir | 500 | fs/nfs/dir.c | nfs_lookup_cache_remove(dir, NULL, name); |
dir | 501 | fs/nfs/dir.c | iput(dir); |
dir | 505 | fs/nfs/dir.c | static int nfs_sillyrename(struct inode *dir, const char *name, int len) |
dir | 511 | fs/nfs/dir.c | dir->i_count++; |
dir | 512 | fs/nfs/dir.c | if (nfs_lookup(dir, name, len, &inode) < 0) |
dir | 524 | fs/nfs/dir.c | ret = nfs_proc_rename(NFS_SERVER(dir), NFS_FH(dir), name, |
dir | 525 | fs/nfs/dir.c | NFS_FH(dir), silly); |
dir | 527 | fs/nfs/dir.c | nfs_lookup_cache_remove(dir, NULL, name); |
dir | 528 | fs/nfs/dir.c | nfs_lookup_cache_remove(dir, NULL, silly); |
dir | 529 | fs/nfs/dir.c | NFS_RENAMED_DIR(inode) = dir; |
dir | 530 | fs/nfs/dir.c | dir->i_count++; |
dir | 538 | fs/nfs/dir.c | struct inode *dir = NFS_RENAMED_DIR(inode); |
dir | 543 | fs/nfs/dir.c | if ((error = nfs_unlink(dir, silly, slen)) < 0) { |
dir | 550 | fs/nfs/dir.c | static int nfs_unlink(struct inode *dir, const char *name, int len) |
dir | 554 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 556 | fs/nfs/dir.c | iput(dir); |
dir | 560 | fs/nfs/dir.c | iput(dir); |
dir | 563 | fs/nfs/dir.c | if ((error = nfs_sillyrename(dir, name, len)) < 0) { |
dir | 564 | fs/nfs/dir.c | error = nfs_proc_remove(NFS_SERVER(dir), NFS_FH(dir), name); |
dir | 566 | fs/nfs/dir.c | nfs_lookup_cache_remove(dir, NULL, name); |
dir | 568 | fs/nfs/dir.c | iput(dir); |
dir | 572 | fs/nfs/dir.c | static int nfs_symlink(struct inode *dir, const char *name, int len, |
dir | 578 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 580 | fs/nfs/dir.c | iput(dir); |
dir | 584 | fs/nfs/dir.c | iput(dir); |
dir | 588 | fs/nfs/dir.c | iput(dir); |
dir | 594 | fs/nfs/dir.c | error = nfs_proc_symlink(NFS_SERVER(dir), NFS_FH(dir), |
dir | 596 | fs/nfs/dir.c | iput(dir); |
dir | 600 | fs/nfs/dir.c | static int nfs_link(struct inode *oldinode, struct inode *dir, |
dir | 608 | fs/nfs/dir.c | iput(dir); |
dir | 611 | fs/nfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 614 | fs/nfs/dir.c | iput(dir); |
dir | 619 | fs/nfs/dir.c | iput(dir); |
dir | 623 | fs/nfs/dir.c | NFS_FH(dir), name); |
dir | 625 | fs/nfs/dir.c | nfs_lookup_cache_remove(dir, oldinode, NULL); |
dir | 627 | fs/nfs/dir.c | iput(dir); |
dir | 296 | fs/nfs/proc.c | int nfs_proc_lookup(struct nfs_server *server, struct nfs_fh *dir, const char *name, |
dir | 312 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 538 | fs/nfs/proc.c | int nfs_proc_create(struct nfs_server *server, struct nfs_fh *dir, |
dir | 551 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 578 | fs/nfs/proc.c | int nfs_proc_remove(struct nfs_server *server, struct nfs_fh *dir, const char *name) |
dir | 589 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 653 | fs/nfs/proc.c | struct nfs_fh *dir, const char *name) |
dir | 665 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 689 | fs/nfs/proc.c | int nfs_proc_symlink(struct nfs_server *server, struct nfs_fh *dir, |
dir | 701 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 727 | fs/nfs/proc.c | int nfs_proc_mkdir(struct nfs_server *server, struct nfs_fh *dir, |
dir | 740 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 767 | fs/nfs/proc.c | int nfs_proc_rmdir(struct nfs_server *server, struct nfs_fh *dir, const char *name) |
dir | 778 | fs/nfs/proc.c | p = xdr_encode_fhandle(p, dir); |
dir | 48 | fs/nfs/symlink.c | static int nfs_follow_link(struct inode *dir, struct inode *inode, |
dir | 56 | fs/nfs/symlink.c | if (!dir) { |
dir | 57 | fs/nfs/symlink.c | dir = current->fs->root; |
dir | 58 | fs/nfs/symlink.c | dir->i_count++; |
dir | 61 | fs/nfs/symlink.c | iput(dir); |
dir | 65 | fs/nfs/symlink.c | iput(dir); |
dir | 71 | fs/nfs/symlink.c | iput(dir); |
dir | 78 | fs/nfs/symlink.c | iput(dir); |
dir | 90 | fs/nfs/symlink.c | error = open_namei(res2, flag, mode, res_inode, dir); |
dir | 55 | fs/proc/fd.c | static int proc_lookupfd(struct inode * dir, const char * name, int len, |
dir | 64 | fs/proc/fd.c | ino = dir->i_ino; |
dir | 67 | fs/proc/fd.c | if (!dir) |
dir | 69 | fs/proc/fd.c | sb = dir->i_sb; |
dir | 70 | fs/proc/fd.c | if (!pid || ino != PROC_PID_FD || !S_ISDIR(dir->i_mode)) { |
dir | 71 | fs/proc/fd.c | iput(dir); |
dir | 77 | fs/proc/fd.c | *result = dir; |
dir | 81 | fs/proc/fd.c | iput(dir); |
dir | 84 | fs/proc/fd.c | iput(dir); |
dir | 87 | fs/proc/fd.c | iput(dir); |
dir | 65 | fs/proc/link.c | static int proc_follow_link(struct inode * dir, struct inode * inode, |
dir | 74 | fs/proc/link.c | if (dir) |
dir | 75 | fs/proc/link.c | iput(dir); |
dir | 151 | fs/proc/root.c | int proc_register(struct proc_dir_entry * dir, struct proc_dir_entry * dp) |
dir | 153 | fs/proc/root.c | dp->next = dir->subdir; |
dir | 154 | fs/proc/root.c | dp->parent = dir; |
dir | 155 | fs/proc/root.c | dir->subdir = dp; |
dir | 157 | fs/proc/root.c | dir->nlink++; |
dir | 161 | fs/proc/root.c | int proc_unregister(struct proc_dir_entry * dir, int ino) |
dir | 163 | fs/proc/root.c | struct proc_dir_entry **p = &dir->subdir, *dp; |
dir | 170 | fs/proc/root.c | dir->nlink--; |
dir | 191 | fs/proc/root.c | int proc_register_dynamic(struct proc_dir_entry * dir, |
dir | 198 | fs/proc/root.c | dp->next = dir->subdir; |
dir | 199 | fs/proc/root.c | dp->parent = dir; |
dir | 200 | fs/proc/root.c | dir->subdir = dp; |
dir | 202 | fs/proc/root.c | dir->nlink++; |
dir | 209 | fs/proc/root.c | static int proc_self_followlink(struct inode * dir, struct inode * inode, |
dir | 212 | fs/proc/root.c | iput(dir); |
dir | 386 | fs/proc/root.c | int proc_lookup(struct inode * dir,const char * name, int len, |
dir | 393 | fs/proc/root.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 394 | fs/proc/root.c | iput(dir); |
dir | 398 | fs/proc/root.c | de = (struct proc_dir_entry *) dir->u.generic_ip; |
dir | 400 | fs/proc/root.c | iput(dir); |
dir | 405 | fs/proc/root.c | *result = dir; |
dir | 413 | fs/proc/root.c | inode = proc_get_inode(dir->i_sb, de->parent->low_ino, de->parent); |
dir | 414 | fs/proc/root.c | iput(dir); |
dir | 428 | fs/proc/root.c | iput(dir); |
dir | 432 | fs/proc/root.c | ino = de->low_ino | (dir->i_ino & ~(0xffff)); |
dir | 434 | fs/proc/root.c | if (!(*result = proc_get_inode(dir->i_sb, ino, de))) { |
dir | 435 | fs/proc/root.c | iput(dir); |
dir | 438 | fs/proc/root.c | iput(dir); |
dir | 442 | fs/proc/root.c | static int proc_root_lookup(struct inode * dir,const char * name, int len, |
dir | 448 | fs/proc/root.c | dir->i_count++; |
dir | 449 | fs/proc/root.c | retval = proc_lookup(dir, name, len, result); |
dir | 451 | fs/proc/root.c | iput(dir); |
dir | 474 | fs/proc/root.c | iput(dir); |
dir | 478 | fs/proc/root.c | if (!(*result = proc_get_inode(dir->i_sb, ino, &proc_pid))) { |
dir | 479 | fs/proc/root.c | iput(dir); |
dir | 482 | fs/proc/root.c | iput(dir); |
dir | 29 | fs/smbfs/dir.c | get_pname(struct inode *dir, const char *name, int len, |
dir | 33 | fs/smbfs/dir.c | get_pname_static(struct inode *dir, const char *name, int len, |
dir | 37 | fs/smbfs/dir.c | smb_iget(struct inode *dir, char *path, struct smb_dirent *finfo); |
dir | 46 | fs/smbfs/dir.c | smb_lookup(struct inode *dir, const char *__name, |
dir | 50 | fs/smbfs/dir.c | smb_create(struct inode *dir, const char *name, int len, int mode, |
dir | 54 | fs/smbfs/dir.c | smb_mkdir(struct inode *dir, const char *name, int len, int mode); |
dir | 57 | fs/smbfs/dir.c | smb_rmdir(struct inode *dir, const char *name, int len); |
dir | 60 | fs/smbfs/dir.c | smb_unlink(struct inode *dir, const char *name, int len); |
dir | 343 | fs/smbfs/dir.c | get_pname_static(struct inode *dir, const char *name, int len, |
dir | 346 | fs/smbfs/dir.c | char *parentname = SMB_INOP(dir)->finfo.path; |
dir | 347 | fs/smbfs/dir.c | int parentlen = SMB_INOP(dir)->finfo.len; |
dir | 412 | fs/smbfs/dir.c | switch (SMB_SERVER(dir)->case_handling) |
dir | 432 | fs/smbfs/dir.c | get_pname(struct inode *dir, const char *name, int len, |
dir | 439 | fs/smbfs/dir.c | if ((res = get_pname_static(dir,name,len,result,&result_len) != 0)) { |
dir | 464 | fs/smbfs/dir.c | smb_iget(struct inode *dir, char *path, struct smb_dirent *finfo) |
dir | 472 | fs/smbfs/dir.c | if (!dir) { |
dir | 485 | fs/smbfs/dir.c | error = smb_proc_getattr(&(SMB_SBP(dir->i_sb)->s_server), |
dir | 506 | fs/smbfs/dir.c | new_inode_info->dir = SMB_INOP(dir); |
dir | 513 | fs/smbfs/dir.c | SMB_INOP(dir)->nused += 1; |
dir | 519 | fs/smbfs/dir.c | root = &(SMB_SERVER(dir)->root); |
dir | 526 | fs/smbfs/dir.c | if (!(inode = iget(dir->i_sb, (int)new_inode_info))) { |
dir | 544 | fs/smbfs/dir.c | struct smb_inode_info *dir = i->dir; |
dir | 552 | fs/smbfs/dir.c | if (dir == NULL) return; |
dir | 554 | fs/smbfs/dir.c | (dir->nused)--; |
dir | 555 | fs/smbfs/dir.c | i = dir; |
dir | 570 | fs/smbfs/dir.c | root->dir = NULL; |
dir | 658 | fs/smbfs/dir.c | smb_lookup(struct inode *dir, const char *__name, int len, |
dir | 669 | fs/smbfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 671 | fs/smbfs/dir.c | iput(dir); |
dir | 679 | fs/smbfs/dir.c | *result = dir; |
dir | 684 | fs/smbfs/dir.c | if ((error = get_pname(dir, __name, len, &name, &len)) < 0) { |
dir | 685 | fs/smbfs/dir.c | iput(dir); |
dir | 689 | fs/smbfs/dir.c | result_info = smb_find_inode(SMB_SERVER(dir), name); |
dir | 701 | fs/smbfs/dir.c | *result = iget(dir->i_sb, (int)result_info); |
dir | 702 | fs/smbfs/dir.c | iput(dir); |
dir | 720 | fs/smbfs/dir.c | if (dir->i_ino == c_ino) { |
dir | 742 | fs/smbfs/dir.c | error = smb_proc_getattr(SMB_SERVER(dir), name, len, &finfo); |
dir | 745 | fs/smbfs/dir.c | iput(dir); |
dir | 750 | fs/smbfs/dir.c | if (!(*result = smb_iget(dir, name, &finfo))) { |
dir | 752 | fs/smbfs/dir.c | iput(dir); |
dir | 757 | fs/smbfs/dir.c | iput(dir); |
dir | 762 | fs/smbfs/dir.c | smb_create(struct inode *dir, const char *name, int len, int mode, |
dir | 771 | fs/smbfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 773 | fs/smbfs/dir.c | iput(dir); |
dir | 778 | fs/smbfs/dir.c | if ((error = get_pname(dir, name, len, &path, &len)) < 0) { |
dir | 779 | fs/smbfs/dir.c | iput(dir); |
dir | 789 | fs/smbfs/dir.c | error = smb_proc_create(SMB_SERVER(dir), path, len, &entry); |
dir | 792 | fs/smbfs/dir.c | iput(dir); |
dir | 796 | fs/smbfs/dir.c | smb_invalid_dir_cache(dir->i_ino); |
dir | 798 | fs/smbfs/dir.c | if (!(*result = smb_iget(dir, path, &entry)) < 0) { |
dir | 800 | fs/smbfs/dir.c | iput(dir); |
dir | 803 | fs/smbfs/dir.c | iput(dir); |
dir | 808 | fs/smbfs/dir.c | smb_mkdir(struct inode *dir, const char *name, int len, int mode) |
dir | 813 | fs/smbfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 815 | fs/smbfs/dir.c | iput(dir); |
dir | 820 | fs/smbfs/dir.c | if ((error = get_pname_static(dir, name, len, path, &len)) < 0) { |
dir | 821 | fs/smbfs/dir.c | iput(dir); |
dir | 825 | fs/smbfs/dir.c | if ((error = smb_proc_mkdir(SMB_SERVER(dir), path, len)) == 0) { |
dir | 826 | fs/smbfs/dir.c | smb_invalid_dir_cache(dir->i_ino); |
dir | 829 | fs/smbfs/dir.c | iput(dir); |
dir | 834 | fs/smbfs/dir.c | smb_rmdir(struct inode *dir, const char *name, int len) |
dir | 839 | fs/smbfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 841 | fs/smbfs/dir.c | iput(dir); |
dir | 844 | fs/smbfs/dir.c | if ((error = get_pname_static(dir, name, len, path, &len)) < 0) { |
dir | 845 | fs/smbfs/dir.c | iput(dir); |
dir | 848 | fs/smbfs/dir.c | if (smb_find_inode(SMB_SERVER(dir), path) != NULL) { |
dir | 851 | fs/smbfs/dir.c | if ((error = smb_proc_rmdir(SMB_SERVER(dir), path, len)) == 0) |
dir | 852 | fs/smbfs/dir.c | smb_invalid_dir_cache(dir->i_ino); |
dir | 854 | fs/smbfs/dir.c | iput(dir); |
dir | 859 | fs/smbfs/dir.c | smb_unlink(struct inode *dir, const char *name, int len) |
dir | 864 | fs/smbfs/dir.c | if (!dir || !S_ISDIR(dir->i_mode)) { |
dir | 866 | fs/smbfs/dir.c | iput(dir); |
dir | 869 | fs/smbfs/dir.c | if ((error = get_pname_static(dir, name, len, path, &len)) < 0) { |
dir | 870 | fs/smbfs/dir.c | iput(dir); |
dir | 873 | fs/smbfs/dir.c | if (smb_find_inode(SMB_SERVER(dir), path) != NULL) { |
dir | 876 | fs/smbfs/dir.c | if ((error = smb_proc_unlink(SMB_SERVER(dir), path, len)) == 0) |
dir | 877 | fs/smbfs/dir.c | smb_invalid_dir_cache(dir->i_ino); |
dir | 879 | fs/smbfs/dir.c | iput(dir); |
dir | 395 | fs/smbfs/inode.c | smb_invalid_dir_cache((unsigned long)(SMB_INOP(inode)->dir)); |
dir | 940 | fs/smbfs/proc.c | smb_proc_readdir_short(struct smb_server *server, struct inode *dir, int fpos, |
dir | 954 | fs/smbfs/proc.c | int dirlen = strlen(SMB_FINFO(dir)->path); |
dir | 957 | fs/smbfs/proc.c | strcpy(mask, SMB_FINFO(dir)->path); |
dir | 1144 | fs/smbfs/proc.c | smb_proc_readdir_long(struct smb_server *server, struct inode *dir, int fpos, |
dir | 1173 | fs/smbfs/proc.c | int dirlen = strlen(SMB_FINFO(dir)->path); |
dir | 1176 | fs/smbfs/proc.c | strcpy(mask, SMB_FINFO(dir)->path); |
dir | 1372 | fs/smbfs/proc.c | smb_proc_readdir(struct smb_server *server, struct inode *dir, int fpos, |
dir | 1376 | fs/smbfs/proc.c | return smb_proc_readdir_long(server, dir, fpos, cache_size, |
dir | 1379 | fs/smbfs/proc.c | return smb_proc_readdir_short(server, dir, fpos, cache_size, |
dir | 769 | fs/super.c | static int do_remount(const char *dir,int flags,char *data) |
dir | 774 | fs/super.c | retval = namei(dir, &dir_i); |
dir | 103 | fs/sysv/ialloc.c | struct inode * sysv_new_inode(const struct inode * dir) |
dir | 111 | fs/sysv/ialloc.c | if (!dir || !(inode = get_empty_inode())) |
dir | 113 | fs/sysv/ialloc.c | sb = dir->i_sb; |
dir | 156 | fs/sysv/ialloc.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
dir | 60 | fs/sysv/namei.c | static struct buffer_head * sysv_find_entry(struct inode * dir, |
dir | 68 | fs/sysv/namei.c | if (!dir) |
dir | 70 | fs/sysv/namei.c | sb = dir->i_sb; |
dir | 78 | fs/sysv/namei.c | while (pos < dir->i_size) { |
dir | 80 | fs/sysv/namei.c | bh = sysv_file_bread(dir,block,0); |
dir | 103 | fs/sysv/namei.c | int sysv_lookup(struct inode * dir,const char * name, int len, |
dir | 111 | fs/sysv/namei.c | if (!dir) |
dir | 113 | fs/sysv/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 114 | fs/sysv/namei.c | iput(dir); |
dir | 117 | fs/sysv/namei.c | if (!(bh = sysv_find_entry(dir,name,len,&de))) { |
dir | 118 | fs/sysv/namei.c | iput(dir); |
dir | 123 | fs/sysv/namei.c | if (!(*result = iget(dir->i_sb,ino))) { |
dir | 124 | fs/sysv/namei.c | iput(dir); |
dir | 127 | fs/sysv/namei.c | iput(dir); |
dir | 141 | fs/sysv/namei.c | static int sysv_add_entry(struct inode * dir, |
dir | 154 | fs/sysv/namei.c | if (!dir) |
dir | 156 | fs/sysv/namei.c | sb = dir->i_sb; |
dir | 168 | fs/sysv/namei.c | bh = sysv_file_bread(dir,block,1); |
dir | 175 | fs/sysv/namei.c | if (pos > dir->i_size) { |
dir | 177 | fs/sysv/namei.c | dir->i_size = pos; |
dir | 178 | fs/sysv/namei.c | dir->i_dirt = 1; |
dir | 186 | fs/sysv/namei.c | dir->i_mtime = dir->i_ctime = CURRENT_TIME; |
dir | 187 | fs/sysv/namei.c | dir->i_dirt = 1; |
dir | 204 | fs/sysv/namei.c | int sysv_create(struct inode * dir,const char * name, int len, int mode, |
dir | 213 | fs/sysv/namei.c | if (!dir) |
dir | 215 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
dir | 217 | fs/sysv/namei.c | iput(dir); |
dir | 223 | fs/sysv/namei.c | error = sysv_add_entry(dir,name,len, &bh ,&de); |
dir | 228 | fs/sysv/namei.c | iput(dir); |
dir | 234 | fs/sysv/namei.c | iput(dir); |
dir | 239 | fs/sysv/namei.c | int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rdev) |
dir | 246 | fs/sysv/namei.c | if (!dir) |
dir | 248 | fs/sysv/namei.c | bh = sysv_find_entry(dir,name,len,&de); |
dir | 251 | fs/sysv/namei.c | iput(dir); |
dir | 254 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
dir | 256 | fs/sysv/namei.c | iput(dir); |
dir | 266 | fs/sysv/namei.c | if (dir->i_mode & S_ISGID) |
dir | 280 | fs/sysv/namei.c | error = sysv_add_entry(dir, name, len, &bh, &de); |
dir | 285 | fs/sysv/namei.c | iput(dir); |
dir | 291 | fs/sysv/namei.c | iput(dir); |
dir | 296 | fs/sysv/namei.c | int sysv_mkdir(struct inode * dir, const char * name, int len, int mode) |
dir | 303 | fs/sysv/namei.c | if (!dir) { |
dir | 304 | fs/sysv/namei.c | iput(dir); |
dir | 307 | fs/sysv/namei.c | bh = sysv_find_entry(dir,name,len,&de); |
dir | 310 | fs/sysv/namei.c | iput(dir); |
dir | 313 | fs/sysv/namei.c | if (dir->i_nlink >= dir->i_sb->sv_link_max) { |
dir | 314 | fs/sysv/namei.c | iput(dir); |
dir | 317 | fs/sysv/namei.c | inode = sysv_new_inode(dir); |
dir | 319 | fs/sysv/namei.c | iput(dir); |
dir | 326 | fs/sysv/namei.c | iput(dir); |
dir | 336 | fs/sysv/namei.c | de->inode = dir->i_ino; |
dir | 342 | fs/sysv/namei.c | if (dir->i_mode & S_ISGID) |
dir | 345 | fs/sysv/namei.c | error = sysv_add_entry(dir, name, len, &bh, &de); |
dir | 347 | fs/sysv/namei.c | iput(dir); |
dir | 354 | fs/sysv/namei.c | dir->i_nlink++; |
dir | 355 | fs/sysv/namei.c | dir->i_dirt = 1; |
dir | 356 | fs/sysv/namei.c | iput(dir); |
dir | 422 | fs/sysv/namei.c | int sysv_rmdir(struct inode * dir, const char * name, int len) |
dir | 430 | fs/sysv/namei.c | bh = sysv_find_entry(dir,name,len,&de); |
dir | 435 | fs/sysv/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
dir | 437 | fs/sysv/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 439 | fs/sysv/namei.c | current->fsuid != dir->i_uid) |
dir | 441 | fs/sysv/namei.c | if (inode->i_dev != dir->i_dev) |
dir | 443 | fs/sysv/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
dir | 467 | fs/sysv/namei.c | dir->i_nlink--; |
dir | 468 | fs/sysv/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 469 | fs/sysv/namei.c | dir->i_dirt=1; |
dir | 472 | fs/sysv/namei.c | iput(dir); |
dir | 478 | fs/sysv/namei.c | int sysv_unlink(struct inode * dir, const char * name, int len) |
dir | 488 | fs/sysv/namei.c | bh = sysv_find_entry(dir,name,len,&de); |
dir | 491 | fs/sysv/namei.c | if (!(inode = iget(dir->i_sb, de->inode))) |
dir | 503 | fs/sysv/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 505 | fs/sysv/namei.c | current->fsuid != dir->i_uid) |
dir | 519 | fs/sysv/namei.c | dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 520 | fs/sysv/namei.c | dir->i_dirt = 1; |
dir | 522 | fs/sysv/namei.c | inode->i_ctime = dir->i_ctime; |
dir | 528 | fs/sysv/namei.c | iput(dir); |
dir | 532 | fs/sysv/namei.c | int sysv_symlink(struct inode * dir, const char * name, int len, const char * symname) |
dir | 543 | fs/sysv/namei.c | if (!(inode = sysv_new_inode(dir))) { |
dir | 544 | fs/sysv/namei.c | iput(dir); |
dir | 551 | fs/sysv/namei.c | iput(dir); |
dir | 567 | fs/sysv/namei.c | bh = sysv_find_entry(dir,name,len,&de); |
dir | 573 | fs/sysv/namei.c | iput(dir); |
dir | 576 | fs/sysv/namei.c | i = sysv_add_entry(dir, name, len, &bh, &de); |
dir | 581 | fs/sysv/namei.c | iput(dir); |
dir | 587 | fs/sysv/namei.c | iput(dir); |
dir | 592 | fs/sysv/namei.c | int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, int len) |
dir | 600 | fs/sysv/namei.c | iput(dir); |
dir | 605 | fs/sysv/namei.c | iput(dir); |
dir | 608 | fs/sysv/namei.c | bh = sysv_find_entry(dir,name,len,&de); |
dir | 611 | fs/sysv/namei.c | iput(dir); |
dir | 615 | fs/sysv/namei.c | error = sysv_add_entry(dir, name, len, &bh, &de); |
dir | 617 | fs/sysv/namei.c | iput(dir); |
dir | 624 | fs/sysv/namei.c | iput(dir); |
dir | 49 | fs/sysv/symlink.c | static int sysv_follow_link(struct inode * dir, struct inode * inode, |
dir | 56 | fs/sysv/symlink.c | if (!dir) { |
dir | 57 | fs/sysv/symlink.c | dir = current->fs->root; |
dir | 58 | fs/sysv/symlink.c | dir->i_count++; |
dir | 61 | fs/sysv/symlink.c | iput(dir); |
dir | 65 | fs/sysv/symlink.c | iput(dir); |
dir | 71 | fs/sysv/symlink.c | iput(dir); |
dir | 76 | fs/sysv/symlink.c | iput(dir); |
dir | 81 | fs/sysv/symlink.c | error = open_namei(bh->b_data,flag,mode,res_inode,dir); |
dir | 37 | fs/ufs/ufs_namei.c | int ufs_lookup (struct inode * dir, const char * name, int len, |
dir | 48 | fs/ufs/ufs_namei.c | (dir->i_ino == UFS_ROOTINO)) { |
dir | 49 | fs/ufs/ufs_namei.c | dir->i_sb->u.ufs_sb.s_flags ^= UFS_DEBUG; |
dir | 51 | fs/ufs/ufs_namei.c | (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) ? |
dir | 60 | fs/ufs/ufs_namei.c | (dir->i_ino == UFS_ROOTINO)) { |
dir | 61 | fs/ufs/ufs_namei.c | dir->i_sb->u.ufs_sb.s_flags ^= UFS_DEBUG_INODE; |
dir | 63 | fs/ufs/ufs_namei.c | (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG_INODE) ? |
dir | 69 | fs/ufs/ufs_namei.c | (dir->i_ino == UFS_ROOTINO)) { |
dir | 70 | fs/ufs/ufs_namei.c | dir->i_sb->u.ufs_sb.s_flags ^= UFS_DEBUG_NAMEI; |
dir | 72 | fs/ufs/ufs_namei.c | (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG_NAMEI) ? |
dir | 78 | fs/ufs/ufs_namei.c | (dir->i_ino == UFS_ROOTINO)) { |
dir | 79 | fs/ufs/ufs_namei.c | dir->i_sb->u.ufs_sb.s_flags ^= UFS_DEBUG_LINKS; |
dir | 81 | fs/ufs/ufs_namei.c | (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG_LINKS) ? |
dir | 86 | fs/ufs/ufs_namei.c | if (dir->i_sb->u.ufs_sb.s_flags & (UFS_DEBUG|UFS_DEBUG_NAMEI)) { |
dir | 88 | fs/ufs/ufs_namei.c | dir->i_ino, name); |
dir | 92 | fs/ufs/ufs_namei.c | for (lfragno = 0; lfragno < (dir->i_blocks)>>1; lfragno++) { |
dir | 93 | fs/ufs/ufs_namei.c | fragno = ufs_bmap(dir, lfragno); |
dir | 96 | fs/ufs/ufs_namei.c | if (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
dir | 98 | fs/ufs/ufs_namei.c | dir->i_ino, lfragno, fragno); |
dir | 104 | fs/ufs/ufs_namei.c | bh = bread(dir->i_dev, fragno, dir->i_sb->s_blocksize); |
dir | 107 | fs/ufs/ufs_namei.c | dir->i_ino, lfragno); |
dir | 112 | fs/ufs/ufs_namei.c | dir->i_sb->s_blocksize) { |
dir | 115 | fs/ufs/ufs_namei.c | if (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
dir | 117 | fs/ufs/ufs_namei.c | dir->i_ino); |
dir | 121 | fs/ufs/ufs_namei.c | if (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
dir | 129 | fs/ufs/ufs_namei.c | *result = iget(dir->i_sb, d->d_ino); |
dir | 134 | fs/ufs/ufs_namei.c | if (dir->i_sb->u.ufs_sb.s_flags & UFS_DEBUG) { |
dir | 75 | fs/ufs/ufs_symlink.c | ufs_follow_link(struct inode * dir, struct inode * inode, |
dir | 87 | fs/ufs/ufs_symlink.c | dir->i_ino, MAJOR(dir->i_dev), MINOR(dir->i_dev)); |
dir | 91 | fs/ufs/ufs_symlink.c | if (!dir) { |
dir | 92 | fs/ufs/ufs_symlink.c | dir = current->fs->root; |
dir | 93 | fs/ufs/ufs_symlink.c | dir->i_count++; |
dir | 96 | fs/ufs/ufs_symlink.c | iput (dir); |
dir | 100 | fs/ufs/ufs_symlink.c | iput (dir); |
dir | 105 | fs/ufs/ufs_symlink.c | iput (dir); |
dir | 118 | fs/ufs/ufs_symlink.c | iput(dir); |
dir | 128 | fs/ufs/ufs_symlink.c | error = open_namei (link, flag, mode, res_inode, dir); |
dir | 80 | fs/umsdos/dir.c | struct inode *dir, /* Point to a description of the super block */ |
dir | 91 | fs/umsdos/dir.c | umsdos_startlookup(dir); |
dir | 93 | fs/umsdos/dir.c | && dir == pseudo_root |
dir | 106 | fs/umsdos/dir.c | ,dir->i_sb->s_mounted->i_ino) == 0){ |
dir | 110 | fs/umsdos/dir.c | || (dir != dir->i_sb->s_mounted && filp->f_pos == 32)){ |
dir | 155 | fs/umsdos/dir.c | ret = fat_readdir(dir,filp,&bufk,umsdos_dir_once); |
dir | 159 | fs/umsdos/dir.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,0); |
dir | 196 | fs/umsdos/dir.c | lret = umsdos_real_lookup (dir,info.fake.fname |
dir | 235 | fs/umsdos/dir.c | ret = umsdos_writeentry (dir,emd_dir,&info,1); |
dir | 252 | fs/umsdos/dir.c | umsdos_endlookup(dir); |
dir | 253 | fs/umsdos/dir.c | PRINTK (("read dir %p pos %Ld ret %d\n",dir,filp->f_pos,ret)); |
dir | 262 | fs/umsdos/dir.c | struct inode *dir, /* Point to a description of the super block */ |
dir | 277 | fs/umsdos/dir.c | ret = umsdos_readdir_x (dir,filp,&bufk,0,&entry,1,umsdos_dir_once); |
dir | 289 | fs/umsdos/dir.c | struct inode *dir, |
dir | 323 | fs/umsdos/dir.c | if (inode->i_sb == dir->i_sb && !umsdos_isinit(inode)){ |
dir | 402 | fs/umsdos/dir.c | umsdos_patch_inode(inode,dir,emd_pos); |
dir | 463 | fs/umsdos/dir.c | struct inode *dir, |
dir | 477 | fs/umsdos/dir.c | struct inode *emddir = umsdos_emd_dir_lookup(dir,0); |
dir | 487 | fs/umsdos/dir.c | fat_readdir (dir,&filp,&bufk,umsdos_dir_search); |
dir | 490 | fs/umsdos/dir.c | inode->u.umsdos_i.i_dir_owner = dir->i_ino; |
dir | 501 | fs/umsdos/dir.c | if (umsdos_readdir_x(dir,&filp,&bufk |
dir | 508 | fs/umsdos/dir.c | umsdos_lookup_patch (dir,inode,entry,bufk.f_pos); |
dir | 521 | fs/umsdos/dir.c | struct inode *dir, |
dir | 526 | fs/umsdos/dir.c | umsdos_patch_inode (dir,NULL,0); |
dir | 527 | fs/umsdos/dir.c | ret = umsdos_real_lookup (dir,"..",2,result); |
dir | 531 | fs/umsdos/dir.c | ret = umsdos_inode2entry (adir,dir,entry); |
dir | 547 | fs/umsdos/dir.c | struct inode *dir = inode; |
dir | 557 | fs/umsdos/dir.c | ret = umsdos_get_dirowner (inode,&dir); |
dir | 560 | fs/umsdos/dir.c | ret = umsdos_inode2entry (dir,inode,&entry); |
dir | 568 | fs/umsdos/dir.c | dir->i_count++; |
dir | 571 | fs/umsdos/dir.c | while (dir != dir->i_sb->s_mounted){ |
dir | 573 | fs/umsdos/dir.c | ret = umsdos_locate_ancestor (dir,&adir,&entry); |
dir | 574 | fs/umsdos/dir.c | iput (dir); |
dir | 575 | fs/umsdos/dir.c | dir = NULL; |
dir | 581 | fs/umsdos/dir.c | dir = adir; |
dir | 592 | fs/umsdos/dir.c | iput (dir); |
dir | 600 | fs/umsdos/dir.c | struct inode *dir, |
dir | 611 | fs/umsdos/dir.c | return dir == pseudo_root |
dir | 620 | fs/umsdos/dir.c | struct inode *dir, |
dir | 628 | fs/umsdos/dir.c | umsdos_startlookup(dir); |
dir | 630 | fs/umsdos/dir.c | *result = dir; |
dir | 631 | fs/umsdos/dir.c | dir->i_count++; |
dir | 634 | fs/umsdos/dir.c | if (pseudo_root != NULL && dir == pseudo_root->i_sb->s_mounted){ |
dir | 654 | fs/umsdos/dir.c | ret = umsdos_real_lookup (dir,"..",2,result); |
dir | 655 | fs/umsdos/dir.c | PRINTK (("ancestor ret %d dir %p *result %p ",ret,dir,*result)); |
dir | 657 | fs/umsdos/dir.c | && *result != dir->i_sb->s_mounted |
dir | 665 | fs/umsdos/dir.c | }else if (umsdos_is_pseudodos(dir,name,len)){ |
dir | 670 | fs/umsdos/dir.c | *result = dir->i_sb->s_mounted; |
dir | 676 | fs/umsdos/dir.c | if (ret == 0) ret = umsdos_findentry (dir,&info,0); |
dir | 690 | fs/umsdos/dir.c | ret = umsdos_real_lookup (dir,info.fake.fname,info.fake.len,result); |
dir | 695 | fs/umsdos/dir.c | umsdos_delentry (dir,&info,S_ISDIR(info.entry.mode)); |
dir | 697 | fs/umsdos/dir.c | umsdos_lookup_patch (dir,inode,&info.entry,info.f_pos); |
dir | 720 | fs/umsdos/dir.c | umsdos_endlookup(dir); |
dir | 721 | fs/umsdos/dir.c | iput (dir); |
dir | 729 | fs/umsdos/dir.c | struct inode *dir, |
dir | 734 | fs/umsdos/dir.c | return umsdos_lookup_x(dir,name,len,result,0); |
dir | 755 | fs/umsdos/dir.c | struct inode *dir; |
dir | 757 | fs/umsdos/dir.c | dir = hlink->i_sb->s_mounted; |
dir | 760 | fs/umsdos/dir.c | dir->i_count++; |
dir | 767 | fs/umsdos/dir.c | if (dir->u.umsdos_i.i_emd_dir == 0){ |
dir | 769 | fs/umsdos/dir.c | ret = umsdos_rlookup_x(dir,start,len,result,1); |
dir | 771 | fs/umsdos/dir.c | ret = umsdos_lookup_x(dir,start,len,result,1); |
dir | 775 | fs/umsdos/dir.c | dir = *result; |
dir | 102 | fs/umsdos/emd.c | struct inode *umsdos_emd_dir_lookup(struct inode *dir, int creat) |
dir | 105 | fs/umsdos/emd.c | if (dir->u.umsdos_i.i_emd_dir != 0){ |
dir | 106 | fs/umsdos/emd.c | ret = iget (dir->i_sb,dir->u.umsdos_i.i_emd_dir); |
dir | 108 | fs/umsdos/emd.c | ,dir->u.umsdos_i.i_emd_dir,ret,ret->i_count)); |
dir | 110 | fs/umsdos/emd.c | umsdos_real_lookup (dir,UMSDOS_EMD_FILE,UMSDOS_EMD_NAMELEN,&ret); |
dir | 114 | fs/umsdos/emd.c | dir->u.umsdos_i.i_emd_dir = ret->i_ino; |
dir | 118 | fs/umsdos/emd.c | dir->i_count++; |
dir | 119 | fs/umsdos/emd.c | code = msdos_create (dir,UMSDOS_EMD_FILE,UMSDOS_EMD_NAMELEN |
dir | 123 | fs/umsdos/emd.c | dir->u.umsdos_i.i_emd_dir = ret->i_ino; |
dir | 163 | fs/umsdos/emd.c | struct inode *dir, |
dir | 198 | fs/umsdos/emd.c | dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 199 | fs/umsdos/emd.c | dir->i_dirt = 1; |
dir | 266 | fs/umsdos/emd.c | struct inode *dir, |
dir | 278 | fs/umsdos/emd.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,1); |
dir | 366 | fs/umsdos/emd.c | struct inode *dir, |
dir | 370 | fs/umsdos/emd.c | int ret = umsdos_find (dir,info,&emd_dir); |
dir | 374 | fs/umsdos/emd.c | ret = umsdos_writeentry(dir,emd_dir,info,0); |
dir | 385 | fs/umsdos/emd.c | struct inode *dir, |
dir | 392 | fs/umsdos/emd.c | ret = umsdos_find (dir,info,&emd_dir); |
dir | 413 | fs/umsdos/emd.c | struct inode *dir, |
dir | 418 | fs/umsdos/emd.c | int ret = umsdos_find (dir,info,&emd_dir); |
dir | 428 | fs/umsdos/emd.c | ret = umsdos_writeentry(dir,emd_dir,info,1); |
dir | 443 | fs/umsdos/emd.c | int umsdos_isempty (struct inode *dir) |
dir | 446 | fs/umsdos/emd.c | struct inode *emd_dir = umsdos_emd_dir_lookup(dir,0); |
dir | 475 | fs/umsdos/emd.c | struct inode *dir, |
dir | 482 | fs/umsdos/emd.c | int ret = umsdos_find (dir,info,&emd_dir); |
dir | 69 | fs/umsdos/inode.c | struct inode *dir, |
dir | 75 | fs/umsdos/inode.c | dir->i_count++; |
dir | 76 | fs/umsdos/inode.c | ret = msdos_lookup (dir,name,len,result); |
dir | 102 | fs/umsdos/inode.c | struct inode *dir, |
dir | 105 | fs/umsdos/inode.c | struct inode *emd_owner = umsdos_emd_dir_lookup(dir,1); |
dir | 106 | fs/umsdos/inode.c | inode->u.umsdos_i.i_dir_owner = dir->i_ino; |
dir | 130 | fs/umsdos/inode.c | struct inode *dir, /* May be NULL */ |
dir | 158 | fs/umsdos/inode.c | if (dir != NULL){ |
dir | 170 | fs/umsdos/inode.c | if (dir != NULL){ |
dir | 181 | fs/umsdos/inode.c | umsdos_set_dirinfo (inode,dir,f_pos); |
dir | 183 | fs/umsdos/inode.c | }else if (dir != NULL){ |
dir | 188 | fs/umsdos/inode.c | struct inode *emd_owner = umsdos_emd_dir_lookup(dir,1); |
dir | 211 | fs/umsdos/inode.c | struct inode *dir = *result = iget(inode->i_sb,ino); |
dir | 212 | fs/umsdos/inode.c | if (dir != NULL){ |
dir | 213 | fs/umsdos/inode.c | umsdos_patch_inode (dir,NULL,0); |
dir | 56 | fs/umsdos/ioctl.c | struct inode *dir, |
dir | 123 | fs/umsdos/ioctl.c | fat_readdir(dir,filp,&bufk,umsdos_ioctl_fill); |
dir | 137 | fs/umsdos/ioctl.c | struct inode *emd_dir = umsdos_emd_dir_lookup (dir,0); |
dir | 181 | fs/umsdos/ioctl.c | struct inode *emd_dir = umsdos_emd_dir_lookup (dir,1); |
dir | 185 | fs/umsdos/ioctl.c | dir->i_op = ret |
dir | 207 | fs/umsdos/ioctl.c | ret = umsdos_newentry (dir,&info); |
dir | 218 | fs/umsdos/ioctl.c | dir->i_count += 2; |
dir | 219 | fs/umsdos/ioctl.c | ret = msdos_rename (dir |
dir | 221 | fs/umsdos/ioctl.c | ,dir |
dir | 239 | fs/umsdos/ioctl.c | ret = umsdos_delentry (dir,&info |
dir | 249 | fs/umsdos/ioctl.c | dir->i_count++; |
dir | 250 | fs/umsdos/ioctl.c | ret = msdos_unlink (dir,data.dos_dirent.d_name |
dir | 260 | fs/umsdos/ioctl.c | dir->i_count++; |
dir | 261 | fs/umsdos/ioctl.c | ret = msdos_rmdir (dir,data.dos_dirent.d_name |
dir | 275 | fs/umsdos/ioctl.c | ret = umsdos_real_lookup (dir,data.dos_dirent.d_name |
dir | 307 | fs/umsdos/ioctl.c | dir->i_sb->u.msdos_sb.options.fs_uid = data.umsdos_dirent.uid; |
dir | 308 | fs/umsdos/ioctl.c | dir->i_sb->u.msdos_sb.options.fs_gid = data.umsdos_dirent.gid; |
dir | 309 | fs/umsdos/ioctl.c | dir->i_sb->u.msdos_sb.options.fs_umask = data.umsdos_dirent.mode; |
dir | 32 | fs/umsdos/namei.c | static int umsdos_waitcreate(struct inode *dir) |
dir | 35 | fs/umsdos/namei.c | if (dir->u.umsdos_i.u.dir_info.creating |
dir | 36 | fs/umsdos/namei.c | && dir->u.umsdos_i.u.dir_info.pid != current->pid){ |
dir | 37 | fs/umsdos/namei.c | sleep_on(&dir->u.umsdos_i.u.dir_info.p); |
dir | 45 | fs/umsdos/namei.c | static void umsdos_waitlookup (struct inode *dir) |
dir | 47 | fs/umsdos/namei.c | while (dir->u.umsdos_i.u.dir_info.looking){ |
dir | 48 | fs/umsdos/namei.c | sleep_on(&dir->u.umsdos_i.u.dir_info.p); |
dir | 54 | fs/umsdos/namei.c | void umsdos_lockcreate (struct inode *dir) |
dir | 88 | fs/umsdos/namei.c | while (umsdos_waitcreate(dir)!=0); |
dir | 89 | fs/umsdos/namei.c | dir->u.umsdos_i.u.dir_info.creating++; |
dir | 90 | fs/umsdos/namei.c | dir->u.umsdos_i.u.dir_info.pid = current->pid; |
dir | 91 | fs/umsdos/namei.c | umsdos_waitlookup (dir); |
dir | 121 | fs/umsdos/namei.c | void umsdos_startlookup (struct inode *dir) |
dir | 123 | fs/umsdos/namei.c | while (umsdos_waitcreate (dir) != 0); |
dir | 124 | fs/umsdos/namei.c | dir->u.umsdos_i.u.dir_info.looking++; |
dir | 130 | fs/umsdos/namei.c | void umsdos_unlockcreate (struct inode *dir) |
dir | 132 | fs/umsdos/namei.c | dir->u.umsdos_i.u.dir_info.creating--; |
dir | 133 | fs/umsdos/namei.c | if (dir->u.umsdos_i.u.dir_info.creating < 0){ |
dir | 135 | fs/umsdos/namei.c | ,dir->u.umsdos_i.u.dir_info.creating); |
dir | 137 | fs/umsdos/namei.c | wake_up (&dir->u.umsdos_i.u.dir_info.p); |
dir | 142 | fs/umsdos/namei.c | void umsdos_endlookup (struct inode *dir) |
dir | 144 | fs/umsdos/namei.c | dir->u.umsdos_i.u.dir_info.looking--; |
dir | 145 | fs/umsdos/namei.c | if (dir->u.umsdos_i.u.dir_info.looking < 0){ |
dir | 147 | fs/umsdos/namei.c | ,dir->u.umsdos_i.u.dir_info.looking); |
dir | 149 | fs/umsdos/namei.c | wake_up (&dir->u.umsdos_i.u.dir_info.p); |
dir | 152 | fs/umsdos/namei.c | static void umsdos_lockcreate (struct inode *dir){} |
dir | 154 | fs/umsdos/namei.c | void umsdos_startlookup (struct inode *dir){} |
dir | 155 | fs/umsdos/namei.c | static void umsdos_unlockcreate (struct inode *dir){} |
dir | 156 | fs/umsdos/namei.c | void umsdos_endlookup (struct inode *dir){} |
dir | 159 | fs/umsdos/namei.c | struct inode *dir, |
dir | 165 | fs/umsdos/namei.c | if (umsdos_is_pseudodos(dir,name,len)){ |
dir | 200 | fs/umsdos/namei.c | struct inode *dir, |
dir | 210 | fs/umsdos/namei.c | int ret = umsdos_nevercreat(dir,name,len,-EEXIST); |
dir | 220 | fs/umsdos/namei.c | info.entry.gid = (dir->i_mode & S_ISGID) |
dir | 221 | fs/umsdos/namei.c | ? dir->i_gid : current->fsgid; |
dir | 225 | fs/umsdos/namei.c | umsdos_lockcreate(dir); |
dir | 226 | fs/umsdos/namei.c | ret = umsdos_newentry (dir,&info); |
dir | 228 | fs/umsdos/namei.c | dir->i_count++; |
dir | 229 | fs/umsdos/namei.c | ret = msdos_create (dir,info.fake.fname,info.fake.len |
dir | 233 | fs/umsdos/namei.c | umsdos_lookup_patch (dir,inode,&info.entry,info.f_pos); |
dir | 235 | fs/umsdos/namei.c | PRINTK (("Creation OK: [%d] %s %d pos %d\n",dir->i_ino |
dir | 262 | fs/umsdos/namei.c | "deleting %s %d %d pos %ld\n",dir->i_ino |
dir | 265 | fs/umsdos/namei.c | umsdos_delentry (dir,&info,0); |
dir | 270 | fs/umsdos/namei.c | umsdos_unlockcreate(dir); |
dir | 273 | fs/umsdos/namei.c | iput (dir); |
dir | 421 | fs/umsdos/namei.c | struct inode * dir, |
dir | 440 | fs/umsdos/namei.c | dir->i_count++; /* We keep the inode in case we need it */ |
dir | 442 | fs/umsdos/namei.c | ret = umsdos_create_any (dir,name,len,mode,0,flags,&inode); |
dir | 461 | fs/umsdos/namei.c | UMSDOS_unlink (dir,name,len); |
dir | 462 | fs/umsdos/namei.c | dir = NULL; |
dir | 465 | fs/umsdos/namei.c | iput (dir); |
dir | 474 | fs/umsdos/namei.c | struct inode * dir, |
dir | 479 | fs/umsdos/namei.c | return umsdos_symlink_x (dir,name,len,symname,S_IFLNK|0777,0); |
dir | 486 | fs/umsdos/namei.c | struct inode * dir, |
dir | 567 | fs/umsdos/namei.c | }else if ((ret = umsdos_nevercreat(dir,name,len,-EPERM))==0){ |
dir | 574 | fs/umsdos/namei.c | umsdos_lockcreate2(dir,olddir); |
dir | 616 | fs/umsdos/namei.c | dir->i_count++; |
dir | 617 | fs/umsdos/namei.c | ret = umsdos_symlink_x (dir,name,len |
dir | 633 | fs/umsdos/namei.c | dir->i_count++; |
dir | 634 | fs/umsdos/namei.c | ret = umsdos_symlink_x (dir,name,len,path |
dir | 642 | fs/umsdos/namei.c | umsdos_unlockcreate(dir); |
dir | 653 | fs/umsdos/namei.c | iput (dir); |
dir | 665 | fs/umsdos/namei.c | struct inode *dir, |
dir | 672 | fs/umsdos/namei.c | return umsdos_create_any (dir,name,len,mode,0,0,result); |
dir | 678 | fs/umsdos/namei.c | struct inode * dir, |
dir | 683 | fs/umsdos/namei.c | int ret = umsdos_nevercreat(dir,name,len,-EEXIST); |
dir | 692 | fs/umsdos/namei.c | info.entry.gid = (dir->i_mode & S_ISGID) |
dir | 693 | fs/umsdos/namei.c | ? dir->i_gid : current->fsgid; |
dir | 697 | fs/umsdos/namei.c | umsdos_lockcreate(dir); |
dir | 699 | fs/umsdos/namei.c | ret = umsdos_newentry (dir,&info); |
dir | 702 | fs/umsdos/namei.c | dir->i_count++; |
dir | 703 | fs/umsdos/namei.c | ret = msdos_mkdir (dir,info.fake.fname,info.fake.len,mode); |
dir | 705 | fs/umsdos/namei.c | umsdos_delentry (dir,&info,1); |
dir | 718 | fs/umsdos/namei.c | ret = umsdos_real_lookup (dir,info.fake.fname |
dir | 733 | fs/umsdos/namei.c | umsdos_unlockcreate(dir); |
dir | 737 | fs/umsdos/namei.c | iput (dir); |
dir | 744 | fs/umsdos/namei.c | struct inode * dir, |
dir | 765 | fs/umsdos/namei.c | int ret = umsdos_create_any (dir,name,len,mode,rdev,0,&inode); |
dir | 774 | fs/umsdos/namei.c | struct inode * dir, |
dir | 865 | fs/umsdos/namei.c | int ret = umsdos_nevercreat(dir,name,len,-EPERM); |
dir | 868 | fs/umsdos/namei.c | dir->i_count++; |
dir | 869 | fs/umsdos/namei.c | ret = UMSDOS_lookup (dir,name,len,&sdir); |
dir | 873 | fs/umsdos/namei.c | umsdos_lockcreate(dir); |
dir | 879 | fs/umsdos/namei.c | if ( !(dir->i_mode & S_ISVTX) || fsuser() || |
dir | 881 | fs/umsdos/namei.c | current->fsuid == dir->i_uid ) { |
dir | 891 | fs/umsdos/namei.c | PRINTK (("isempty ret %d nlink %d ",ret,dir->i_nlink)); |
dir | 894 | fs/umsdos/namei.c | dir->i_count++; |
dir | 898 | fs/umsdos/namei.c | umsdos_findentry (dir,&info,2); |
dir | 899 | fs/umsdos/namei.c | ret = msdos_rmdir (dir,info.fake.fname |
dir | 902 | fs/umsdos/namei.c | ret = umsdos_delentry (dir,&info,1); |
dir | 917 | fs/umsdos/namei.c | umsdos_unlockcreate(dir); |
dir | 920 | fs/umsdos/namei.c | iput (dir); |
dir | 928 | fs/umsdos/namei.c | struct inode * dir, |
dir | 932 | fs/umsdos/namei.c | int ret = umsdos_nevercreat(dir,name,len,-EPERM); |
dir | 937 | fs/umsdos/namei.c | umsdos_lockcreate(dir); |
dir | 938 | fs/umsdos/namei.c | ret = umsdos_findentry(dir,&info,1); |
dir | 942 | fs/umsdos/namei.c | if ( !(dir->i_mode & S_ISVTX) || fsuser() || |
dir | 944 | fs/umsdos/namei.c | current->fsuid == dir->i_uid ) { |
dir | 959 | fs/umsdos/namei.c | dir->i_count++; |
dir | 960 | fs/umsdos/namei.c | ret = UMSDOS_lookup (dir,name,len,&inode); |
dir | 984 | fs/umsdos/namei.c | ret = umsdos_delentry (dir,&info,0); |
dir | 987 | fs/umsdos/namei.c | dir->i_count++; |
dir | 988 | fs/umsdos/namei.c | ret = msdos_unlink_umsdos (dir,info.fake.fname |
dir | 1000 | fs/umsdos/namei.c | umsdos_unlockcreate(dir); |
dir | 1003 | fs/umsdos/namei.c | iput (dir); |
dir | 64 | fs/umsdos/rdir.c | struct inode *dir, |
dir | 73 | fs/umsdos/rdir.c | && dir == dir->i_sb->s_mounted |
dir | 74 | fs/umsdos/rdir.c | && dir == pseudo_root->i_sb->s_mounted; |
dir | 75 | fs/umsdos/rdir.c | return fat_readdir(dir,filp,&bufk,rdir_filldir); |
dir | 84 | fs/umsdos/rdir.c | struct inode *dir, |
dir | 96 | fs/umsdos/rdir.c | && dir == dir->i_sb->s_mounted |
dir | 97 | fs/umsdos/rdir.c | && dir == pseudo_root->i_sb->s_mounted){ |
dir | 106 | fs/umsdos/rdir.c | ret = umsdos_real_lookup (dir,name,len,result); |
dir | 124 | fs/umsdos/rdir.c | iput (dir); |
dir | 128 | fs/umsdos/rdir.c | struct inode *dir, |
dir | 133 | fs/umsdos/rdir.c | return umsdos_rlookup_x(dir,name,len,result,0); |
dir | 137 | fs/umsdos/rdir.c | struct inode *dir, |
dir | 156 | fs/umsdos/rdir.c | if (umsdos_is_pseudodos(dir,name,len)){ |
dir | 167 | fs/umsdos/rdir.c | umsdos_lockcreate (dir); |
dir | 168 | fs/umsdos/rdir.c | dir->i_count++; |
dir | 169 | fs/umsdos/rdir.c | ret = msdos_rmdir (dir,name,len); |
dir | 172 | fs/umsdos/rdir.c | dir->i_count++; |
dir | 173 | fs/umsdos/rdir.c | ret = UMSDOS_rlookup (dir,name,len,&sdir); |
dir | 191 | fs/umsdos/rdir.c | dir->i_count++; |
dir | 192 | fs/umsdos/rdir.c | ret = msdos_rmdir (dir,name,len); |
dir | 201 | fs/umsdos/rdir.c | umsdos_unlockcreate (dir); |
dir | 203 | fs/umsdos/rdir.c | iput (dir); |
dir | 52 | fs/umsdos/symlink.c | struct inode * dir, |
dir | 65 | fs/umsdos/symlink.c | if (!dir) { |
dir | 66 | fs/umsdos/symlink.c | dir = current->fs[1].root; |
dir | 67 | fs/umsdos/symlink.c | dir->i_count++; |
dir | 86 | fs/umsdos/symlink.c | ret = open_namei(path,flag,mode,res_inode,dir); |
dir | 88 | fs/umsdos/symlink.c | dir = NULL; |
dir | 97 | fs/umsdos/symlink.c | iput(dir); |
dir | 226 | fs/vfat/namei.c | static int vfat_find(struct inode *dir,const char *name,int len, |
dir | 394 | fs/vfat/namei.c | static int vfat_create_shortname(struct inode *dir, const char *name, |
dir | 426 | fs/vfat/namei.c | res = vfat_find(dir, msdos_name, len, 0, 0, 0, &sinfo); |
dir | 514 | fs/vfat/namei.c | if (MSDOS_SB(dir->i_sb)->options.numtail == 0) { |
dir | 515 | fs/vfat/namei.c | res = vfat_find(dir, msdos_name, totlen, 0, 0, 0, &sinfo); |
dir | 536 | fs/vfat/namei.c | res = vfat_find(dir, msdos_name, totlen, 0, 0, 0, &sinfo); |
dir | 542 | fs/vfat/namei.c | static loff_t vfat_find_free_slots(struct inode *dir,int slots) |
dir | 544 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 559 | fs/vfat/namei.c | ino = fat_get_entry(dir,&curr,&bh,&de); |
dir | 584 | fs/vfat/namei.c | ino = fat_get_entry(dir,&curr,&bh,&de); |
dir | 587 | fs/vfat/namei.c | if (dir->i_ino == MSDOS_ROOT_INO) return -ENOSPC; |
dir | 588 | fs/vfat/namei.c | if ((res = fat_add_cluster(dir)) < 0) return res; |
dir | 589 | fs/vfat/namei.c | ino = fat_get_entry(dir,&curr,&bh,&de); |
dir | 714 | fs/vfat/namei.c | static int vfat_build_slots(struct inode *dir,const char *name,int len, |
dir | 723 | fs/vfat/namei.c | xlate = MSDOS_SB(dir->i_sb)->options.unicode_xlate; |
dir | 739 | fs/vfat/namei.c | res = vfat_create_shortname(dir, name, len, msdos_name); |
dir | 802 | fs/vfat/namei.c | static int vfat_find(struct inode *dir,const char *name,int len, |
dir | 805 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 824 | fs/vfat/namei.c | res = fat_readdirx(dir,&fil,(void *)&vf,vfat_readdir_cb,NULL,1,find_long,0); |
dir | 846 | fs/vfat/namei.c | res = vfat_build_slots(dir, name, len, ds, &slots, &is_long); |
dir | 855 | fs/vfat/namei.c | offset = vfat_find_free_slots(dir, slots); |
dir | 865 | fs/vfat/namei.c | sinfo_out->ino = fat_get_entry(dir,&offset,&bh,&de); |
dir | 875 | fs/vfat/namei.c | dir->i_ctime = dir->i_mtime = dir->i_atime = CURRENT_TIME; |
dir | 876 | fs/vfat/namei.c | dir->i_dirt = 1; |
dir | 881 | fs/vfat/namei.c | fat_date_unix2dos(dir->i_mtime,&de->time,&de->date); |
dir | 909 | fs/vfat/namei.c | int vfat_lookup(struct inode *dir,const char *name,int len, |
dir | 919 | fs/vfat/namei.c | if (!dir) return -ENOENT; |
dir | 920 | fs/vfat/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 921 | fs/vfat/namei.c | iput(dir); |
dir | 926 | fs/vfat/namei.c | *result = dir; |
dir | 930 | fs/vfat/namei.c | ino = fat_parent_ino(dir,0); |
dir | 931 | fs/vfat/namei.c | iput(dir); |
dir | 933 | fs/vfat/namei.c | if (!(*result = iget(dir->i_sb,ino))) return -EACCES; |
dir | 936 | fs/vfat/namei.c | if (dcache_lookup(dir, name, len, (unsigned long *) &ino) && ino) { |
dir | 937 | fs/vfat/namei.c | iput(dir); |
dir | 938 | fs/vfat/namei.c | if (!(*result = iget(dir->i_sb, ino))) |
dir | 943 | fs/vfat/namei.c | if ((res = vfat_find(dir,name,len,1,0,0,&sinfo)) < 0) { |
dir | 944 | fs/vfat/namei.c | iput(dir); |
dir | 948 | fs/vfat/namei.c | if (!(*result = iget(dir->i_sb,sinfo.ino))) { |
dir | 949 | fs/vfat/namei.c | iput(dir); |
dir | 956 | fs/vfat/namei.c | iput(dir); |
dir | 961 | fs/vfat/namei.c | iput(dir); |
dir | 969 | fs/vfat/namei.c | fat_fs_panic(dir->i_sb,"vfat_lookup: Can't happen"); |
dir | 970 | fs/vfat/namei.c | iput(dir); |
dir | 974 | fs/vfat/namei.c | iput(dir); |
dir | 979 | fs/vfat/namei.c | static int vfat_create_entry(struct inode *dir,const char *name,int len, |
dir | 982 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 990 | fs/vfat/namei.c | res = vfat_find(dir, name, len, 1, 1, is_dir, &sinfo); |
dir | 999 | fs/vfat/namei.c | ino = fat_get_entry(dir, &offset, &bh, &de); |
dir | 1007 | fs/vfat/namei.c | if ((*result = iget(dir->i_sb,ino)) != NULL) |
dir | 1015 | fs/vfat/namei.c | dir->i_version = event; |
dir | 1016 | fs/vfat/namei.c | dcache_add(dir, name, len, ino); |
dir | 1021 | fs/vfat/namei.c | int vfat_create(struct inode *dir,const char *name,int len,int mode, |
dir | 1026 | fs/vfat/namei.c | if (!dir) return -ENOENT; |
dir | 1029 | fs/vfat/namei.c | res = vfat_create_entry(dir,name,len,0,result); |
dir | 1033 | fs/vfat/namei.c | iput(dir); |
dir | 1037 | fs/vfat/namei.c | static int vfat_create_a_dotdir(struct inode *dir,struct inode *parent, |
dir | 1041 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1049 | fs/vfat/namei.c | dir->i_atime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 1050 | fs/vfat/namei.c | dir->i_dirt = 1; |
dir | 1056 | fs/vfat/namei.c | fat_date_unix2dos(dir->i_mtime,&de->time,&de->date); |
dir | 1062 | fs/vfat/namei.c | if ((dot = iget(dir->i_sb,ino)) != NULL) |
dir | 1068 | fs/vfat/namei.c | dot->i_size = dir->i_size; |
dir | 1069 | fs/vfat/namei.c | MSDOS_I(dot)->i_start = MSDOS_I(dir)->i_start; |
dir | 1070 | fs/vfat/namei.c | dot->i_nlink = dir->i_nlink; |
dir | 1083 | fs/vfat/namei.c | static int vfat_create_dotdirs(struct inode *dir, struct inode *parent) |
dir | 1085 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1092 | fs/vfat/namei.c | if ((res = fat_add_cluster(dir)) < 0) return res; |
dir | 1097 | fs/vfat/namei.c | if ((res = fat_get_entry(dir,&offset,&bh,&de)) < 0) return res; |
dir | 1100 | fs/vfat/namei.c | res = vfat_create_a_dotdir(dir, parent, bh, de, res, MSDOS_DOT, 1); |
dir | 1108 | fs/vfat/namei.c | if ((res = fat_get_entry(dir,&offset,&bh,&de)) < 0) { |
dir | 1114 | fs/vfat/namei.c | res = vfat_create_a_dotdir(dir, parent, bh, de, res, MSDOS_DOTDOT, 0); |
dir | 1122 | fs/vfat/namei.c | static int vfat_empty(struct inode *dir) |
dir | 1124 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1129 | fs/vfat/namei.c | if (dir->i_count > 1) |
dir | 1131 | fs/vfat/namei.c | if (MSDOS_I(dir)->i_start) { /* may be zero in mkdir */ |
dir | 1134 | fs/vfat/namei.c | while (fat_get_entry(dir,&pos,&bh,&de) > -1) { |
dir | 1151 | fs/vfat/namei.c | static int vfat_rmdir_free_ino(struct inode *dir,struct buffer_head *bh, |
dir | 1154 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1159 | fs/vfat/namei.c | if (!(inode = iget(dir->i_sb,ino))) return -ENOENT; |
dir | 1164 | fs/vfat/namei.c | if (dir->i_dev != inode->i_dev || dir == inode) { |
dir | 1174 | fs/vfat/namei.c | inode->i_mtime = dir->i_mtime = CURRENT_TIME; |
dir | 1175 | fs/vfat/namei.c | inode->i_atime = dir->i_atime = CURRENT_TIME; |
dir | 1176 | fs/vfat/namei.c | dir->i_nlink--; |
dir | 1177 | fs/vfat/namei.c | inode->i_dirt = dir->i_dirt = 1; |
dir | 1185 | fs/vfat/namei.c | static int vfat_unlink_free_ino(struct inode *dir,struct buffer_head *bh, |
dir | 1188 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1190 | fs/vfat/namei.c | if (!(inode = iget(dir->i_sb,ino))) return -ENOENT; |
dir | 1196 | fs/vfat/namei.c | inode->i_mtime = dir->i_mtime = CURRENT_TIME; |
dir | 1197 | fs/vfat/namei.c | inode->i_atime = dir->i_atime = CURRENT_TIME; |
dir | 1198 | fs/vfat/namei.c | dir->i_version = ++event; |
dir | 1200 | fs/vfat/namei.c | inode->i_dirt = dir->i_dirt = 1; |
dir | 1208 | fs/vfat/namei.c | static int vfat_remove_entry(struct inode *dir,struct slot_info *sinfo, |
dir | 1212 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1218 | fs/vfat/namei.c | res = fat_get_entry(dir, &offset, bh, de); |
dir | 1221 | fs/vfat/namei.c | res = vfat_rmdir_free_ino(dir,*bh,*de,res); |
dir | 1223 | fs/vfat/namei.c | res = vfat_unlink_free_ino(dir,*bh,*de,res,nospc); |
dir | 1230 | fs/vfat/namei.c | res = fat_get_entry(dir, &offset, bh, de); |
dir | 1243 | fs/vfat/namei.c | static int vfat_rmdirx(struct inode *dir,const char *name,int len) |
dir | 1245 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1255 | fs/vfat/namei.c | res = vfat_find(dir,name,len,1,0,0,&sinfo); |
dir | 1258 | fs/vfat/namei.c | res = vfat_remove_entry(dir,&sinfo,&bh,&de,1,0); |
dir | 1265 | fs/vfat/namei.c | dir->i_version = ++event; |
dir | 1273 | fs/vfat/namei.c | int vfat_rmdir(struct inode *dir,const char *name,int len) |
dir | 1277 | fs/vfat/namei.c | res = vfat_rmdirx(dir, name, len); |
dir | 1278 | fs/vfat/namei.c | iput(dir); |
dir | 1283 | fs/vfat/namei.c | struct inode *dir, |
dir | 1288 | fs/vfat/namei.c | struct super_block *sb = dir->i_sb; |
dir | 1295 | fs/vfat/namei.c | if ((res = vfat_find(dir,name,len,1,0,0,&sinfo)) < 0) |
dir | 1299 | fs/vfat/namei.c | res = vfat_remove_entry(dir,&sinfo,&bh,&de,0,nospc); |
dir | 1313 | fs/vfat/namei.c | int vfat_mkdir(struct inode *dir,const char *name,int len,int mode) |
dir | 1319 | fs/vfat/namei.c | if ((res = vfat_create_entry(dir,name,len,1,&inode)) < 0) { |
dir | 1321 | fs/vfat/namei.c | iput(dir); |
dir | 1325 | fs/vfat/namei.c | dir->i_nlink++; |
dir | 1329 | fs/vfat/namei.c | res = vfat_create_dotdirs(inode, dir); |
dir | 1333 | fs/vfat/namei.c | iput(dir); |
dir | 1335 | fs/vfat/namei.c | if (vfat_rmdir(dir,name,len) < 0) |
dir | 1336 | fs/vfat/namei.c | fat_fs_panic(dir->i_sb,"rmdir in mkdir failed"); |
dir | 1342 | fs/vfat/namei.c | int vfat_unlink(struct inode *dir,const char *name,int len) |
dir | 1346 | fs/vfat/namei.c | res = vfat_unlinkx (dir,name,len,1); |
dir | 1347 | fs/vfat/namei.c | iput(dir); |
dir | 306 | fs/xiafs/bitmap.c | struct inode * xiafs_new_inode(struct inode * dir) |
dir | 312 | fs/xiafs/bitmap.c | sb = dir->i_sb; |
dir | 313 | fs/xiafs/bitmap.c | if (!dir || !(inode = get_empty_inode())) |
dir | 318 | fs/xiafs/bitmap.c | tmp=get_free_ibit(sb, dir->i_ino); |
dir | 327 | fs/xiafs/bitmap.c | inode->i_gid = (dir->i_mode & S_ISGID) ? dir->i_gid : current->fsgid; |
dir | 116 | fs/xiafs/namei.c | int xiafs_lookup(struct inode * dir, const char * name, int len, |
dir | 124 | fs/xiafs/namei.c | if (!dir) |
dir | 126 | fs/xiafs/namei.c | if (!S_ISDIR(dir->i_mode)) { |
dir | 127 | fs/xiafs/namei.c | iput(dir); |
dir | 130 | fs/xiafs/namei.c | if (!(bh = xiafs_find_entry(dir, name, len, &dep, NULL))) { |
dir | 131 | fs/xiafs/namei.c | iput(dir); |
dir | 136 | fs/xiafs/namei.c | if (!(*result = iget(dir->i_sb, ino))) { |
dir | 137 | fs/xiafs/namei.c | iput(dir); |
dir | 140 | fs/xiafs/namei.c | iput(dir); |
dir | 154 | fs/xiafs/namei.c | static struct buffer_head * xiafs_add_entry(struct inode * dir, |
dir | 163 | fs/xiafs/namei.c | if (!dir || !namelen || namelen > _XIAFS_NAME_LEN) |
dir | 166 | fs/xiafs/namei.c | if (dir->i_size & (XIAFS_ZSIZE(dir->i_sb) - 1)) { |
dir | 172 | fs/xiafs/namei.c | bh = xiafs_bread(dir, pos >> XIAFS_ZSIZE_BITS(dir->i_sb), pos ? 1:0); |
dir | 187 | fs/xiafs/namei.c | while (offset < XIAFS_ZSIZE(dir->i_sb)) { |
dir | 188 | fs/xiafs/namei.c | if (pos >= dir->i_size) { |
dir | 192 | fs/xiafs/namei.c | de->d_rec_len=XIAFS_ZSIZE(dir->i_sb); |
dir | 193 | fs/xiafs/namei.c | dir->i_size += XIAFS_ZSIZE(dir->i_sb); |
dir | 194 | fs/xiafs/namei.c | dir->i_dirt = 1; |
dir | 196 | fs/xiafs/namei.c | if (de->d_ino > dir->i_sb->u.xiafs_sb.s_ninodes || |
dir | 198 | fs/xiafs/namei.c | (char *)de+de->d_rec_len > bh->b_data+XIAFS_ZSIZE(dir->i_sb) || |
dir | 220 | fs/xiafs/namei.c | dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 221 | fs/xiafs/namei.c | dir->i_dirt = 1; |
dir | 236 | fs/xiafs/namei.c | if (offset > XIAFS_ZSIZE(dir->i_sb)) { |
dir | 240 | fs/xiafs/namei.c | pos+=XIAFS_ZSIZE(dir->i_sb); |
dir | 245 | fs/xiafs/namei.c | int xiafs_create(struct inode * dir, const char * name, int len, int mode, |
dir | 253 | fs/xiafs/namei.c | if (!dir) |
dir | 255 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
dir | 257 | fs/xiafs/namei.c | iput(dir); |
dir | 263 | fs/xiafs/namei.c | bh = xiafs_add_entry(dir, name, len, &de, NULL); |
dir | 268 | fs/xiafs/namei.c | iput(dir); |
dir | 274 | fs/xiafs/namei.c | iput(dir); |
dir | 279 | fs/xiafs/namei.c | int xiafs_mknod(struct inode *dir, const char *name, int len, int mode, int rdev) |
dir | 285 | fs/xiafs/namei.c | if (!dir) |
dir | 287 | fs/xiafs/namei.c | bh = xiafs_find_entry(dir,name,len,&de, NULL); |
dir | 290 | fs/xiafs/namei.c | iput(dir); |
dir | 293 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
dir | 295 | fs/xiafs/namei.c | iput(dir); |
dir | 305 | fs/xiafs/namei.c | if (dir->i_mode & S_ISGID) |
dir | 320 | fs/xiafs/namei.c | bh = xiafs_add_entry(dir, name, len, &de, NULL); |
dir | 325 | fs/xiafs/namei.c | iput(dir); |
dir | 331 | fs/xiafs/namei.c | iput(dir); |
dir | 336 | fs/xiafs/namei.c | int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode) |
dir | 342 | fs/xiafs/namei.c | bh = xiafs_find_entry(dir,name,len,&de, NULL); |
dir | 345 | fs/xiafs/namei.c | iput(dir); |
dir | 348 | fs/xiafs/namei.c | if (dir->i_nlink > 64000) { |
dir | 349 | fs/xiafs/namei.c | iput(dir); |
dir | 352 | fs/xiafs/namei.c | inode = xiafs_new_inode(dir); |
dir | 354 | fs/xiafs/namei.c | iput(dir); |
dir | 358 | fs/xiafs/namei.c | inode->i_size = XIAFS_ZSIZE(dir->i_sb); |
dir | 363 | fs/xiafs/namei.c | iput(dir); |
dir | 375 | fs/xiafs/namei.c | de->d_ino = dir->i_ino; |
dir | 378 | fs/xiafs/namei.c | de->d_rec_len=XIAFS_ZSIZE(dir->i_sb)-12; |
dir | 383 | fs/xiafs/namei.c | if (dir->i_mode & S_ISGID) |
dir | 386 | fs/xiafs/namei.c | bh = xiafs_add_entry(dir, name, len, &de, NULL); |
dir | 388 | fs/xiafs/namei.c | iput(dir); |
dir | 395 | fs/xiafs/namei.c | dir->i_nlink++; |
dir | 396 | fs/xiafs/namei.c | dir->i_dirt = 1; |
dir | 397 | fs/xiafs/namei.c | iput(dir); |
dir | 486 | fs/xiafs/namei.c | int xiafs_rmdir(struct inode * dir, const char * name, int len) |
dir | 494 | fs/xiafs/namei.c | bh = xiafs_find_entry(dir, name, len, &de, &de_pre); |
dir | 499 | fs/xiafs/namei.c | if (!(inode = iget(dir->i_sb, de->d_ino))) |
dir | 501 | fs/xiafs/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 503 | fs/xiafs/namei.c | current->fsuid != dir->i_uid) |
dir | 505 | fs/xiafs/namei.c | if (inode->i_dev != dir->i_dev) |
dir | 507 | fs/xiafs/namei.c | if (inode == dir) /* we may not delete ".", but "../dir" is ok */ |
dir | 527 | fs/xiafs/namei.c | dir->i_nlink--; |
dir | 528 | fs/xiafs/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 529 | fs/xiafs/namei.c | dir->i_dirt=1; |
dir | 532 | fs/xiafs/namei.c | iput(dir); |
dir | 538 | fs/xiafs/namei.c | int xiafs_unlink(struct inode * dir, const char * name, int len) |
dir | 548 | fs/xiafs/namei.c | bh = xiafs_find_entry(dir, name, len, &de, &de_pre); |
dir | 551 | fs/xiafs/namei.c | if (!(inode = iget(dir->i_sb, de->d_ino))) |
dir | 563 | fs/xiafs/namei.c | if ((dir->i_mode & S_ISVTX) && !fsuser() && |
dir | 565 | fs/xiafs/namei.c | current->fsuid != dir->i_uid) |
dir | 573 | fs/xiafs/namei.c | inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME; |
dir | 574 | fs/xiafs/namei.c | dir->i_dirt = 1; |
dir | 581 | fs/xiafs/namei.c | iput(dir); |
dir | 585 | fs/xiafs/namei.c | int xiafs_symlink(struct inode * dir, const char * name, |
dir | 594 | fs/xiafs/namei.c | bh = xiafs_find_entry(dir,name,len, &de, NULL); |
dir | 597 | fs/xiafs/namei.c | iput(dir); |
dir | 600 | fs/xiafs/namei.c | if (!(inode = xiafs_new_inode(dir))) { |
dir | 601 | fs/xiafs/namei.c | iput(dir); |
dir | 608 | fs/xiafs/namei.c | iput(dir); |
dir | 621 | fs/xiafs/namei.c | bh = xiafs_add_entry(dir, name, len, &de, NULL); |
dir | 626 | fs/xiafs/namei.c | iput(dir); |
dir | 632 | fs/xiafs/namei.c | iput(dir); |
dir | 637 | fs/xiafs/namei.c | int xiafs_link(struct inode * oldinode, struct inode * dir, |
dir | 645 | fs/xiafs/namei.c | iput(dir); |
dir | 650 | fs/xiafs/namei.c | iput(dir); |
dir | 653 | fs/xiafs/namei.c | bh = xiafs_find_entry(dir, name, len, &de, NULL); |
dir | 656 | fs/xiafs/namei.c | iput(dir); |
dir | 660 | fs/xiafs/namei.c | bh = xiafs_add_entry(dir, name, len, &de, NULL); |
dir | 662 | fs/xiafs/namei.c | iput(dir); |
dir | 669 | fs/xiafs/namei.c | iput(dir); |
dir | 77 | fs/xiafs/symlink.c | static int xiafs_follow_link(struct inode * dir, struct inode * inode, |
dir | 84 | fs/xiafs/symlink.c | if (!dir) { |
dir | 85 | fs/xiafs/symlink.c | dir = current->fs->root; |
dir | 86 | fs/xiafs/symlink.c | dir->i_count++; |
dir | 89 | fs/xiafs/symlink.c | iput(dir); |
dir | 93 | fs/xiafs/symlink.c | iput(dir); |
dir | 103 | fs/xiafs/symlink.c | iput(dir); |
dir | 108 | fs/xiafs/symlink.c | iput(dir); |
dir | 113 | fs/xiafs/symlink.c | error = open_namei(bh->b_data,flag,mode,res_inode,dir); |
dir | 39 | include/asm-alpha/ioctl.h | #define _IOC(dir,type,nr,size) \ |
dir | 41 | include/asm-alpha/ioctl.h | (((dir) << _IOC_DIRSHIFT) | \ |
dir | 356 | include/asm-alpha/pgtable.h | extern inline pmd_t * pmd_offset(pgd_t * dir, unsigned long address) |
dir | 358 | include/asm-alpha/pgtable.h | return (pmd_t *) pgd_page(*dir) + ((address >> PMD_SHIFT) & (PTRS_PER_PAGE - 1)); |
dir | 362 | include/asm-alpha/pgtable.h | extern inline pte_t * pte_offset(pmd_t * dir, unsigned long address) |
dir | 364 | include/asm-alpha/pgtable.h | return (pte_t *) pmd_page(*dir) + ((address >> PAGE_SHIFT) & (PTRS_PER_PAGE - 1)); |
dir | 49 | include/asm-i386/ioctl.h | #define _IOC(dir,type,nr,size) \ |
dir | 50 | include/asm-i386/ioctl.h | (((dir) << _IOC_DIRSHIFT) | \ |
dir | 359 | include/asm-i386/pgtable.h | extern inline pmd_t * pmd_offset(pgd_t * dir, unsigned long address) |
dir | 361 | include/asm-i386/pgtable.h | return (pmd_t *) dir; |
dir | 365 | include/asm-i386/pgtable.h | extern inline pte_t * pte_offset(pmd_t * dir, unsigned long address) |
dir | 367 | include/asm-i386/pgtable.h | return (pte_t *) pmd_page(*dir) + ((address >> PAGE_SHIFT) & (PTRS_PER_PTE - 1)); |
dir | 16 | include/asm-m68k/atari_joystick.h | char dir; |
dir | 54 | include/asm-m68k/ioctl.h | #define _IOC(dir,type,nr,size) \ |
dir | 55 | include/asm-m68k/ioctl.h | (((dir) << _IOC_DIRSHIFT) | \ |
dir | 319 | include/asm-m68k/pgtable.h | extern inline pmd_t * pmd_offset(pgd_t * dir, unsigned long address) |
dir | 321 | include/asm-m68k/pgtable.h | return (pmd_t *) pgd_page(*dir) + ((address >> PMD_SHIFT) & (PTRS_PER_PMD-1)); |
dir | 339 | include/asm-m68k/pgtable.h | pgd_t *dir; |
dir | 343 | include/asm-m68k/pgtable.h | dir = pgd_offset_k(vaddr); |
dir | 344 | include/asm-m68k/pgtable.h | pmdp = pmd_offset(dir,vaddr); |
dir | 353 | include/asm-m68k/pgtable.h | pgd_t *dir; |
dir | 357 | include/asm-m68k/pgtable.h | dir = pgd_offset_k(vaddr); |
dir | 358 | include/asm-m68k/pgtable.h | pmdp = pmd_offset(dir,vaddr); |
dir | 55 | include/asm-mips/ioctl.h | #define _IOC(dir,type,nr,size) \ |
dir | 56 | include/asm-mips/ioctl.h | (((dir) << _IOC_DIRSHIFT) | \ |
dir | 350 | include/asm-mips/pgtable.h | extern inline pmd_t * pmd_offset(pgd_t * dir, unsigned long address) |
dir | 352 | include/asm-mips/pgtable.h | return (pmd_t *) dir; |
dir | 356 | include/asm-mips/pgtable.h | extern inline pte_t * pte_offset(pmd_t * dir, unsigned long address) |
dir | 358 | include/asm-mips/pgtable.h | return (pte_t *) (pmd_page(*dir) + (PT_OFFSET - PAGE_OFFSET)) + |
dir | 34 | include/asm-ppc/ioctl.h | #define _IOC(dir,type,nr,size) \ |
dir | 35 | include/asm-ppc/ioctl.h | (((dir) << _IOC_DIRSHIFT) | \ |
dir | 294 | include/asm-ppc/pgtable.h | extern inline pmd_t * pmd_offset(pgd_t * dir, unsigned long address) |
dir | 296 | include/asm-ppc/pgtable.h | return (pmd_t *) dir; |
dir | 300 | include/asm-ppc/pgtable.h | extern inline pte_t * pte_offset(pmd_t * dir, unsigned long address) |
dir | 302 | include/asm-ppc/pgtable.h | return (pte_t *) pmd_page(*dir) + ((address >> PAGE_SHIFT) & (PTRS_PER_PTE - 1)); |
dir | 27 | include/asm-sparc/ioctl.h | #define _IOC(dir,type,nr,size) \ |
dir | 28 | include/asm-sparc/ioctl.h | (((dir) << _IOC_DIRSHIFT) | \ |
dir | 62 | include/linux/affs_fs.h | extern int affs_lookup(struct inode * dir,const char * name, int len, |
dir | 74 | include/linux/affs_fs.h | extern int affs_parent_ino(struct inode *dir); |
dir | 65 | include/linux/ext_fs.h | extern int ext_lookup(struct inode * dir,const char * name, int len, |
dir | 67 | include/linux/ext_fs.h | extern int ext_create(struct inode * dir,const char * name, int len, int mode, |
dir | 69 | include/linux/ext_fs.h | extern int ext_mkdir(struct inode * dir, const char * name, int len, int mode); |
dir | 70 | include/linux/ext_fs.h | extern int ext_rmdir(struct inode * dir, const char * name, int len); |
dir | 71 | include/linux/ext_fs.h | extern int ext_unlink(struct inode * dir, const char * name, int len); |
dir | 74 | include/linux/ext_fs.h | extern int ext_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
dir | 75 | include/linux/ext_fs.h | extern int ext_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
dir | 78 | include/linux/ext_fs.h | extern struct inode * ext_new_inode(const struct inode * dir); |
dir | 170 | include/linux/iso_fs.h | extern int isofs_lookup(struct inode * dir,const char * name, int len, |
dir | 91 | include/linux/minix_fs.h | extern int minix_lookup(struct inode * dir,const char * name, int len, |
dir | 93 | include/linux/minix_fs.h | extern int minix_create(struct inode * dir,const char * name, int len, int mode, |
dir | 95 | include/linux/minix_fs.h | extern int minix_mkdir(struct inode * dir, const char * name, int len, int mode); |
dir | 96 | include/linux/minix_fs.h | extern int minix_rmdir(struct inode * dir, const char * name, int len); |
dir | 97 | include/linux/minix_fs.h | extern int minix_unlink(struct inode * dir, const char * name, int len); |
dir | 100 | include/linux/minix_fs.h | extern int minix_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
dir | 101 | include/linux/minix_fs.h | extern int minix_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
dir | 104 | include/linux/minix_fs.h | extern struct inode * minix_new_inode(const struct inode * dir); |
dir | 182 | include/linux/msdos_fs.h | extern int fat_get_entry(struct inode *dir,loff_t *pos,struct buffer_head **bh, |
dir | 184 | include/linux/msdos_fs.h | extern int fat_scan(struct inode *dir,const char *name,struct buffer_head **res_bh, |
dir | 186 | include/linux/msdos_fs.h | extern int fat_parent_ino(struct inode *dir,int locked); |
dir | 187 | include/linux/msdos_fs.h | extern int fat_subdirs(struct inode *dir); |
dir | 245 | include/linux/msdos_fs.h | extern int msdos_lookup(struct inode *dir,const char *name,int len, |
dir | 247 | include/linux/msdos_fs.h | extern int msdos_create(struct inode *dir,const char *name,int len,int mode, |
dir | 249 | include/linux/msdos_fs.h | extern int msdos_rmdir(struct inode *dir,const char *name,int len); |
dir | 250 | include/linux/msdos_fs.h | extern int msdos_mkdir(struct inode *dir,const char *name,int len,int mode); |
dir | 251 | include/linux/msdos_fs.h | extern int msdos_unlink(struct inode *dir,const char *name,int len); |
dir | 252 | include/linux/msdos_fs.h | extern int msdos_unlink_umsdos(struct inode *dir,const char *name,int len); |
dir | 29 | include/linux/ncp_fs_i.h | struct ncp_inode_info *dir; |
dir | 64 | include/linux/nfs_fs.h | extern int nfs_proc_lookup(struct nfs_server *server, struct nfs_fh *dir, |
dir | 75 | include/linux/nfs_fs.h | extern int nfs_proc_create(struct nfs_server *server, struct nfs_fh *dir, |
dir | 78 | include/linux/nfs_fs.h | extern int nfs_proc_remove(struct nfs_server *server, struct nfs_fh *dir, |
dir | 84 | include/linux/nfs_fs.h | struct nfs_fh *dir, const char *name); |
dir | 85 | include/linux/nfs_fs.h | extern int nfs_proc_symlink(struct nfs_server *server, struct nfs_fh *dir, |
dir | 87 | include/linux/nfs_fs.h | extern int nfs_proc_mkdir(struct nfs_server *server, struct nfs_fh *dir, |
dir | 90 | include/linux/nfs_fs.h | extern int nfs_proc_rmdir(struct nfs_server *server, struct nfs_fh *dir, |
dir | 146 | include/linux/smb_fs.h | int smb_proc_readdir(struct smb_server *server, struct inode *dir, |
dir | 28 | include/linux/smb_fs_i.h | struct smb_inode_info *dir; |
dir | 364 | include/linux/sysv_fs.h | extern int sysv_lookup(struct inode * dir,const char * name, int len, |
dir | 366 | include/linux/sysv_fs.h | extern int sysv_create(struct inode * dir,const char * name, int len, int mode, |
dir | 368 | include/linux/sysv_fs.h | extern int sysv_mkdir(struct inode * dir, const char * name, int len, int mode); |
dir | 369 | include/linux/sysv_fs.h | extern int sysv_rmdir(struct inode * dir, const char * name, int len); |
dir | 370 | include/linux/sysv_fs.h | extern int sysv_unlink(struct inode * dir, const char * name, int len); |
dir | 373 | include/linux/sysv_fs.h | extern int sysv_link(struct inode * oldinode, struct inode * dir, const char * name, int len); |
dir | 374 | include/linux/sysv_fs.h | extern int sysv_mknod(struct inode * dir, const char * name, int len, int mode, int rdev); |
dir | 377 | include/linux/sysv_fs.h | extern struct inode * sysv_new_inode(const struct inode * dir); |
dir | 67 | include/linux/xia_fs.h | extern int xiafs_lookup(struct inode * dir,const char * name, int len, |
dir | 69 | include/linux/xia_fs.h | extern int xiafs_create(struct inode * dir,const char * name, int len, int mode, |
dir | 71 | include/linux/xia_fs.h | extern int xiafs_mkdir(struct inode * dir, const char * name, int len, int mode); |
dir | 72 | include/linux/xia_fs.h | extern int xiafs_rmdir(struct inode * dir, const char * name, int len); |
dir | 73 | include/linux/xia_fs.h | extern int xiafs_unlink(struct inode * dir, const char * name, int len); |
dir | 76 | include/linux/xia_fs.h | extern int xiafs_link(struct inode * oldinode, struct inode * dir, |
dir | 78 | include/linux/xia_fs.h | extern int xiafs_mknod(struct inode * dir, const char * name, int len, |
dir | 83 | include/linux/xia_fs.h | extern struct inode * xiafs_new_inode(struct inode * dir); |
dir | 986 | mm/filemap.c | pgd_t * dir; |
dir | 990 | mm/filemap.c | dir = pgd_offset(vma->vm_mm, address); |
dir | 993 | mm/filemap.c | error |= filemap_sync_pmd_range(dir, address, end - address, vma, flags); |
dir | 995 | mm/filemap.c | dir++; |
dir | 89 | mm/memory.c | static inline void free_one_pmd(pmd_t * dir) |
dir | 93 | mm/memory.c | if (pmd_none(*dir)) |
dir | 95 | mm/memory.c | if (pmd_bad(*dir)) { |
dir | 96 | mm/memory.c | printk("free_one_pmd: bad directory entry %08lx\n", pmd_val(*dir)); |
dir | 97 | mm/memory.c | pmd_clear(dir); |
dir | 100 | mm/memory.c | pte = pte_offset(dir, 0); |
dir | 101 | mm/memory.c | pmd_clear(dir); |
dir | 105 | mm/memory.c | static inline void free_one_pgd(pgd_t * dir) |
dir | 110 | mm/memory.c | if (pgd_none(*dir)) |
dir | 112 | mm/memory.c | if (pgd_bad(*dir)) { |
dir | 113 | mm/memory.c | printk("free_one_pgd: bad directory entry %08lx\n", pgd_val(*dir)); |
dir | 114 | mm/memory.c | pgd_clear(dir); |
dir | 117 | mm/memory.c | pmd = pmd_offset(dir, 0); |
dir | 118 | mm/memory.c | pgd_clear(dir); |
dir | 344 | mm/memory.c | static inline void zap_pmd_range(pgd_t * dir, unsigned long address, unsigned long size) |
dir | 349 | mm/memory.c | if (pgd_none(*dir)) |
dir | 351 | mm/memory.c | if (pgd_bad(*dir)) { |
dir | 352 | mm/memory.c | printk("zap_pmd_range: bad pgd (%08lx)\n", pgd_val(*dir)); |
dir | 353 | mm/memory.c | pgd_clear(dir); |
dir | 356 | mm/memory.c | pmd = pmd_offset(dir, address); |
dir | 373 | mm/memory.c | pgd_t * dir; |
dir | 376 | mm/memory.c | dir = pgd_offset(mm, address); |
dir | 379 | mm/memory.c | zap_pmd_range(dir, address, end - address); |
dir | 381 | mm/memory.c | dir++; |
dir | 426 | mm/memory.c | pgd_t * dir; |
dir | 432 | mm/memory.c | dir = pgd_offset(current->mm, address); |
dir | 435 | mm/memory.c | pmd_t *pmd = pmd_alloc(dir, address); |
dir | 443 | mm/memory.c | dir++; |
dir | 499 | mm/memory.c | pgd_t * dir; |
dir | 504 | mm/memory.c | dir = pgd_offset(current->mm, from); |
dir | 507 | mm/memory.c | pmd_t *pmd = pmd_alloc(dir, from); |
dir | 515 | mm/memory.c | dir++; |
dir | 74 | mm/mprotect.c | pgd_t *dir; |
dir | 77 | mm/mprotect.c | dir = pgd_offset(current->mm, start); |
dir | 80 | mm/mprotect.c | change_pmd_range(dir, start, end - start, newprot); |
dir | 82 | mm/mprotect.c | dir++; |
dir | 164 | mm/swapfile.c | pte_t *dir, unsigned int type, unsigned long page) |
dir | 166 | mm/swapfile.c | pte_t pte = *dir; |
dir | 179 | mm/swapfile.c | set_pte(dir, pte_mkdirty(pte)); |
dir | 185 | mm/swapfile.c | if (pte_val(*dir) != pte_val(pte)) { |
dir | 189 | mm/swapfile.c | set_pte(dir, pte_mkwrite(pte_mkdirty(mk_pte(page, vma->vm_page_prot)))); |
dir | 195 | mm/swapfile.c | static inline int unuse_pmd(struct vm_area_struct * vma, pmd_t *dir, |
dir | 202 | mm/swapfile.c | if (pmd_none(*dir)) |
dir | 204 | mm/swapfile.c | if (pmd_bad(*dir)) { |
dir | 205 | mm/swapfile.c | printk("unuse_pmd: bad pmd (%08lx)\n", pmd_val(*dir)); |
dir | 206 | mm/swapfile.c | pmd_clear(dir); |
dir | 209 | mm/swapfile.c | pte = pte_offset(dir, address); |
dir | 224 | mm/swapfile.c | static inline int unuse_pgd(struct vm_area_struct * vma, pgd_t *dir, |
dir | 231 | mm/swapfile.c | if (pgd_none(*dir)) |
dir | 233 | mm/swapfile.c | if (pgd_bad(*dir)) { |
dir | 234 | mm/swapfile.c | printk("unuse_pgd: bad pgd (%08lx)\n", pgd_val(*dir)); |
dir | 235 | mm/swapfile.c | pgd_clear(dir); |
dir | 238 | mm/swapfile.c | pmd = pmd_offset(dir, address); |
dir | 73 | mm/vmalloc.c | static inline void free_area_pmd(pgd_t * dir, unsigned long address, unsigned long size) |
dir | 78 | mm/vmalloc.c | if (pgd_none(*dir)) |
dir | 80 | mm/vmalloc.c | if (pgd_bad(*dir)) { |
dir | 81 | mm/vmalloc.c | printk("free_area_pmd: bad pgd (%08lx)\n", pgd_val(*dir)); |
dir | 82 | mm/vmalloc.c | pgd_clear(dir); |
dir | 85 | mm/vmalloc.c | pmd = pmd_offset(dir, address); |
dir | 99 | mm/vmalloc.c | pgd_t * dir; |
dir | 102 | mm/vmalloc.c | dir = pgd_offset(&init_mm, address); |
dir | 105 | mm/vmalloc.c | free_area_pmd(dir, address, end - address); |
dir | 107 | mm/vmalloc.c | dir++; |
dir | 156 | mm/vmalloc.c | pgd_t * dir; |
dir | 159 | mm/vmalloc.c | dir = pgd_offset(&init_mm, address); |
dir | 162 | mm/vmalloc.c | pmd_t *pmd = pmd_alloc_kernel(dir, address); |
dir | 167 | mm/vmalloc.c | set_pgdir(address, *dir); |
dir | 169 | mm/vmalloc.c | dir++; |
dir | 217 | mm/vmalloc.c | pgd_t * dir; |
dir | 221 | mm/vmalloc.c | dir = pgd_offset(&init_mm, address); |
dir | 224 | mm/vmalloc.c | pmd_t *pmd = pmd_alloc_kernel(dir, address); |
dir | 229 | mm/vmalloc.c | set_pgdir(address, *dir); |
dir | 231 | mm/vmalloc.c | dir++; |
dir | 160 | mm/vmscan.c | pmd_t *dir, unsigned long address, unsigned long end, int dma, int wait) |
dir | 165 | mm/vmscan.c | if (pmd_none(*dir)) |
dir | 167 | mm/vmscan.c | if (pmd_bad(*dir)) { |
dir | 168 | mm/vmscan.c | printk("swap_out_pmd: bad pmd (%08lx)\n", pmd_val(*dir)); |
dir | 169 | mm/vmscan.c | pmd_clear(dir); |
dir | 173 | mm/vmscan.c | pte = pte_offset(dir, address); |
dir | 192 | mm/vmscan.c | pgd_t *dir, unsigned long address, unsigned long end, int dma, int wait) |
dir | 197 | mm/vmscan.c | if (pgd_none(*dir)) |
dir | 199 | mm/vmscan.c | if (pgd_bad(*dir)) { |
dir | 200 | mm/vmscan.c | printk("swap_out_pgd: bad pgd (%08lx)\n", pgd_val(*dir)); |
dir | 201 | mm/vmscan.c | pgd_clear(dir); |
dir | 205 | mm/vmscan.c | pmd = pmd_offset(dir, address); |