diff options
Diffstat (limited to 'fs/jffs2/fs.c')
-rw-r--r-- | fs/jffs2/fs.c | 43 |
1 files changed, 25 insertions, 18 deletions
diff --git a/fs/jffs2/fs.c b/fs/jffs2/fs.c index 2e0123867cb1..9a8c97c264c2 100644 --- a/fs/jffs2/fs.c +++ b/fs/jffs2/fs.c | |||
@@ -39,7 +39,7 @@ int jffs2_do_setattr (struct inode *inode, struct iattr *iattr) | |||
39 | int ret; | 39 | int ret; |
40 | int alloc_type = ALLOC_NORMAL; | 40 | int alloc_type = ALLOC_NORMAL; |
41 | 41 | ||
42 | D1(printk(KERN_DEBUG "jffs2_setattr(): ino #%lu\n", inode->i_ino)); | 42 | jffs2_dbg(1, "%s(): ino #%lu\n", __func__, inode->i_ino); |
43 | 43 | ||
44 | /* Special cases - we don't want more than one data node | 44 | /* Special cases - we don't want more than one data node |
45 | for these types on the medium at any time. So setattr | 45 | for these types on the medium at any time. So setattr |
@@ -50,7 +50,8 @@ int jffs2_do_setattr (struct inode *inode, struct iattr *iattr) | |||
50 | /* For these, we don't actually need to read the old node */ | 50 | /* For these, we don't actually need to read the old node */ |
51 | mdatalen = jffs2_encode_dev(&dev, inode->i_rdev); | 51 | mdatalen = jffs2_encode_dev(&dev, inode->i_rdev); |
52 | mdata = (char *)&dev; | 52 | mdata = (char *)&dev; |
53 | D1(printk(KERN_DEBUG "jffs2_setattr(): Writing %d bytes of kdev_t\n", mdatalen)); | 53 | jffs2_dbg(1, "%s(): Writing %d bytes of kdev_t\n", |
54 | __func__, mdatalen); | ||
54 | } else if (S_ISLNK(inode->i_mode)) { | 55 | } else if (S_ISLNK(inode->i_mode)) { |
55 | mutex_lock(&f->sem); | 56 | mutex_lock(&f->sem); |
56 | mdatalen = f->metadata->size; | 57 | mdatalen = f->metadata->size; |
@@ -66,7 +67,8 @@ int jffs2_do_setattr (struct inode *inode, struct iattr *iattr) | |||
66 | return ret; | 67 | return ret; |
67 | } | 68 | } |
68 | mutex_unlock(&f->sem); | 69 | mutex_unlock(&f->sem); |
69 | D1(printk(KERN_DEBUG "jffs2_setattr(): Writing %d bytes of symlink target\n", mdatalen)); | 70 | jffs2_dbg(1, "%s(): Writing %d bytes of symlink target\n", |
71 | __func__, mdatalen); | ||
70 | } | 72 | } |
71 | 73 | ||
72 | ri = jffs2_alloc_raw_inode(); | 74 | ri = jffs2_alloc_raw_inode(); |
@@ -233,7 +235,8 @@ void jffs2_evict_inode (struct inode *inode) | |||
233 | struct jffs2_sb_info *c = JFFS2_SB_INFO(inode->i_sb); | 235 | struct jffs2_sb_info *c = JFFS2_SB_INFO(inode->i_sb); |
234 | struct jffs2_inode_info *f = JFFS2_INODE_INFO(inode); | 236 | struct jffs2_inode_info *f = JFFS2_INODE_INFO(inode); |
235 | 237 | ||
236 | D1(printk(KERN_DEBUG "jffs2_evict_inode(): ino #%lu mode %o\n", inode->i_ino, inode->i_mode)); | 238 | jffs2_dbg(1, "%s(): ino #%lu mode %o\n", |
239 | __func__, inode->i_ino, inode->i_mode); | ||
237 | truncate_inode_pages(&inode->i_data, 0); | 240 | truncate_inode_pages(&inode->i_data, 0); |
238 | end_writeback(inode); | 241 | end_writeback(inode); |
239 | jffs2_do_clear_inode(c, f); | 242 | jffs2_do_clear_inode(c, f); |
@@ -249,7 +252,7 @@ struct inode *jffs2_iget(struct super_block *sb, unsigned long ino) | |||
249 | dev_t rdev = 0; | 252 | dev_t rdev = 0; |
250 | int ret; | 253 | int ret; |
251 | 254 | ||
252 | D1(printk(KERN_DEBUG "jffs2_iget(): ino == %lu\n", ino)); | 255 | jffs2_dbg(1, "%s(): ino == %lu\n", __func__, ino); |
253 | 256 | ||
254 | inode = iget_locked(sb, ino); | 257 | inode = iget_locked(sb, ino); |
255 | if (!inode) | 258 | if (!inode) |
@@ -320,7 +323,7 @@ struct inode *jffs2_iget(struct super_block *sb, unsigned long ino) | |||
320 | printk(KERN_NOTICE "Device node has strange size %d\n", f->metadata->size); | 323 | printk(KERN_NOTICE "Device node has strange size %d\n", f->metadata->size); |
321 | goto error_io; | 324 | goto error_io; |
322 | } | 325 | } |
323 | D1(printk(KERN_DEBUG "Reading device numbers from flash\n")); | 326 | jffs2_dbg(1, "Reading device numbers from flash\n"); |
324 | ret = jffs2_read_dnode(c, f, f->metadata, (char *)&jdev, 0, f->metadata->size); | 327 | ret = jffs2_read_dnode(c, f, f->metadata, (char *)&jdev, 0, f->metadata->size); |
325 | if (ret < 0) { | 328 | if (ret < 0) { |
326 | /* Eep */ | 329 | /* Eep */ |
@@ -344,7 +347,7 @@ struct inode *jffs2_iget(struct super_block *sb, unsigned long ino) | |||
344 | 347 | ||
345 | mutex_unlock(&f->sem); | 348 | mutex_unlock(&f->sem); |
346 | 349 | ||
347 | D1(printk(KERN_DEBUG "jffs2_read_inode() returning\n")); | 350 | jffs2_dbg(1, "jffs2_read_inode() returning\n"); |
348 | unlock_new_inode(inode); | 351 | unlock_new_inode(inode); |
349 | return inode; | 352 | return inode; |
350 | 353 | ||
@@ -362,11 +365,13 @@ void jffs2_dirty_inode(struct inode *inode, int flags) | |||
362 | struct iattr iattr; | 365 | struct iattr iattr; |
363 | 366 | ||
364 | if (!(inode->i_state & I_DIRTY_DATASYNC)) { | 367 | if (!(inode->i_state & I_DIRTY_DATASYNC)) { |
365 | D2(printk(KERN_DEBUG "jffs2_dirty_inode() not calling setattr() for ino #%lu\n", inode->i_ino)); | 368 | jffs2_dbg(2, "%s(): not calling setattr() for ino #%lu\n", |
369 | __func__, inode->i_ino); | ||
366 | return; | 370 | return; |
367 | } | 371 | } |
368 | 372 | ||
369 | D1(printk(KERN_DEBUG "jffs2_dirty_inode() calling setattr() for ino #%lu\n", inode->i_ino)); | 373 | jffs2_dbg(1, "%s(): calling setattr() for ino #%lu\n", |
374 | __func__, inode->i_ino); | ||
370 | 375 | ||
371 | iattr.ia_valid = ATTR_MODE|ATTR_UID|ATTR_GID|ATTR_ATIME|ATTR_MTIME|ATTR_CTIME; | 376 | iattr.ia_valid = ATTR_MODE|ATTR_UID|ATTR_GID|ATTR_ATIME|ATTR_MTIME|ATTR_CTIME; |
372 | iattr.ia_mode = inode->i_mode; | 377 | iattr.ia_mode = inode->i_mode; |
@@ -414,7 +419,8 @@ struct inode *jffs2_new_inode (struct inode *dir_i, umode_t mode, struct jffs2_r | |||
414 | struct jffs2_inode_info *f; | 419 | struct jffs2_inode_info *f; |
415 | int ret; | 420 | int ret; |
416 | 421 | ||
417 | D1(printk(KERN_DEBUG "jffs2_new_inode(): dir_i %ld, mode 0x%x\n", dir_i->i_ino, mode)); | 422 | jffs2_dbg(1, "%s(): dir_i %ld, mode 0x%x\n", |
423 | __func__, dir_i->i_ino, mode); | ||
418 | 424 | ||
419 | c = JFFS2_SB_INFO(sb); | 425 | c = JFFS2_SB_INFO(sb); |
420 | 426 | ||
@@ -550,17 +556,17 @@ int jffs2_do_fill_super(struct super_block *sb, void *data, int silent) | |||
550 | if ((ret = jffs2_do_mount_fs(c))) | 556 | if ((ret = jffs2_do_mount_fs(c))) |
551 | goto out_inohash; | 557 | goto out_inohash; |
552 | 558 | ||
553 | D1(printk(KERN_DEBUG "jffs2_do_fill_super(): Getting root inode\n")); | 559 | jffs2_dbg(1, "%s(): Getting root inode\n", __func__); |
554 | root_i = jffs2_iget(sb, 1); | 560 | root_i = jffs2_iget(sb, 1); |
555 | if (IS_ERR(root_i)) { | 561 | if (IS_ERR(root_i)) { |
556 | D1(printk(KERN_WARNING "get root inode failed\n")); | 562 | jffs2_dbg(1, "get root inode failed\n"); |
557 | ret = PTR_ERR(root_i); | 563 | ret = PTR_ERR(root_i); |
558 | goto out_root; | 564 | goto out_root; |
559 | } | 565 | } |
560 | 566 | ||
561 | ret = -ENOMEM; | 567 | ret = -ENOMEM; |
562 | 568 | ||
563 | D1(printk(KERN_DEBUG "jffs2_do_fill_super(): d_alloc_root()\n")); | 569 | jffs2_dbg(1, "%s(): d_alloc_root()\n", __func__); |
564 | sb->s_root = d_alloc_root(root_i); | 570 | sb->s_root = d_alloc_root(root_i); |
565 | if (!sb->s_root) | 571 | if (!sb->s_root) |
566 | goto out_root_i; | 572 | goto out_root_i; |
@@ -620,20 +626,21 @@ struct jffs2_inode_info *jffs2_gc_fetch_inode(struct jffs2_sb_info *c, | |||
620 | */ | 626 | */ |
621 | inode = ilookup(OFNI_BS_2SFFJ(c), inum); | 627 | inode = ilookup(OFNI_BS_2SFFJ(c), inum); |
622 | if (!inode) { | 628 | if (!inode) { |
623 | D1(printk(KERN_DEBUG "ilookup() failed for ino #%u; inode is probably deleted.\n", | 629 | jffs2_dbg(1, "ilookup() failed for ino #%u; inode is probably deleted.\n", |
624 | inum)); | 630 | inum); |
625 | 631 | ||
626 | spin_lock(&c->inocache_lock); | 632 | spin_lock(&c->inocache_lock); |
627 | ic = jffs2_get_ino_cache(c, inum); | 633 | ic = jffs2_get_ino_cache(c, inum); |
628 | if (!ic) { | 634 | if (!ic) { |
629 | D1(printk(KERN_DEBUG "Inode cache for ino #%u is gone.\n", inum)); | 635 | jffs2_dbg(1, "Inode cache for ino #%u is gone\n", |
636 | inum); | ||
630 | spin_unlock(&c->inocache_lock); | 637 | spin_unlock(&c->inocache_lock); |
631 | return NULL; | 638 | return NULL; |
632 | } | 639 | } |
633 | if (ic->state != INO_STATE_CHECKEDABSENT) { | 640 | if (ic->state != INO_STATE_CHECKEDABSENT) { |
634 | /* Wait for progress. Don't just loop */ | 641 | /* Wait for progress. Don't just loop */ |
635 | D1(printk(KERN_DEBUG "Waiting for ino #%u in state %d\n", | 642 | jffs2_dbg(1, "Waiting for ino #%u in state %d\n", |
636 | ic->ino, ic->state)); | 643 | ic->ino, ic->state); |
637 | sleep_on_spinunlock(&c->inocache_wq, &c->inocache_lock); | 644 | sleep_on_spinunlock(&c->inocache_wq, &c->inocache_lock); |
638 | } else { | 645 | } else { |
639 | spin_unlock(&c->inocache_lock); | 646 | spin_unlock(&c->inocache_lock); |