Lee Trager
2009-Feb-20 17:45 UTC
[PATCH] Backport for 2.6.27 and 2.6.26 on the experimental branch
I have updated my backport patch to apply cleanly to the experimental btrfs branch as well as fix a couple of mistakes I had. I am still having lockup issues on 2.6.26. My best guess right now is that there is some sort of race condition going on. I''m trying to track it down but I''m not having any luck. If someone could please help me that would be great. Thanks, Lee diff -Naur btrfs-orig/async-thread.c btrfs/async-thread.c --- btrfs-orig/async-thread.c 2009-02-20 12:10:13.000000000 -0500 +++ btrfs/async-thread.c 2009-02-20 12:13:20.000000000 -0500 @@ -20,7 +20,10 @@ #include <linux/list.h> #include <linux/spinlock.h> #include <linux/freezer.h> +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) #include <linux/ftrace.h> +#endif #include "async-thread.h" #define WORK_QUEUED_BIT 0 diff -Naur btrfs-orig/compat.h btrfs/compat.h --- btrfs-orig/compat.h 2009-02-20 12:10:14.000000000 -0500 +++ btrfs/compat.h 2009-02-20 12:11:30.000000000 -0500 @@ -1,7 +1,33 @@ #ifndef _COMPAT_H_ #define _COMPAT_H_ +#include <linux/version.h> + #define btrfs_drop_nlink(inode) drop_nlink(inode) #define btrfs_inc_nlink(inode) inc_nlink(inode) +#if LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 27) +static inline struct dentry *d_obtain_alias(struct inode *inode) +{ + struct dentry *d; + + if (!inode) + return NULL; + if (IS_ERR(inode)) + return ERR_CAST(inode); + + d = d_alloc_anon(inode); + if (!d) + iput(inode); + return d; +} +#endif + +#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 28) +#define __pagevec_lru_add_file __pagevec_lru_add +#define open_bdev_exclusive open_bdev_excl +#define close_bdev_exclusive(bdev, mode) close_bdev_excl(bdev) +typedef unsigned __bitwise__ fmode_t; +#endif + #endif /* _COMPAT_H_ */ diff -Naur btrfs-orig/delayed-ref.c btrfs/delayed-ref.c --- btrfs-orig/delayed-ref.c 2009-02-20 12:10:22.000000000 -0500 +++ btrfs/delayed-ref.c 2009-02-20 12:16:21.000000000 -0500 @@ -18,7 +18,10 @@ #include <linux/sched.h> #include <linux/sort.h> +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) #include <linux/ftrace.h> +#endif #include "ctree.h" #include "delayed-ref.h" #include "transaction.h" diff -Naur btrfs-orig/delayed-unlink.c btrfs/delayed-unlink.c --- btrfs-orig/delayed-unlink.c 2009-02-20 12:10:22.000000000 -0500 +++ btrfs/delayed-unlink.c 2009-02-20 12:15:01.000000000 -0500 @@ -18,7 +18,10 @@ #include <linux/sched.h> #include <linux/sort.h> +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) #include <linux/ftrace.h> +#endif #include "ctree.h" #include "delayed-unlink.h" #include "transaction.h" diff -Naur btrfs-orig/export.h btrfs/export.h --- btrfs-orig/export.h 2009-02-20 12:10:15.000000000 -0500 +++ btrfs/export.h 2009-02-20 12:11:30.000000000 -0500 @@ -16,4 +16,32 @@ u64 parent_root_objectid; } __attribute__ ((packed)); +// BTRFS needs the btrfs from fid_type which was added in 2.6.27 +// All I did was copy the btrfs defse which was found in +// linux-2.6.27/include/linux/exportfs.h +#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 27) +enum btrfs_fid_type { + /* + * 64 bit object ID, 64 bit root object ID, + * 32 bit generation number. + */ + FILEID_BTRFS_WITHOUT_PARENT = 0x4d, + + /* + * 64 bit object ID, 64 bit root object ID, + * 32 bit generation number, + * 64 bit parent object ID, 32 bit parent generation. + */ + FILEID_BTRFS_WITH_PARENT = 0x4e, + + /* + * 64 bit object ID, 64 bit root object ID, + * 32 bit generation number, + * 64 bit parent object ID, 32 bit parent generation, + * 64 bit parent root object ID. + */ + FILEID_BTRFS_WITH_PARENT_ROOT = 0x4f, +}; +#endif + #endif diff -Naur btrfs-orig/extent_io.c btrfs/extent_io.c --- btrfs-orig/extent_io.c 2009-02-20 12:10:20.000000000 -0500 +++ btrfs/extent_io.c 2009-02-20 12:11:30.000000000 -0500 @@ -2847,6 +2847,7 @@ return sector; } +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29) int extent_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, __u64 start, __u64 len, get_extent_t *get_extent) { @@ -2938,6 +2939,7 @@ GFP_NOFS); return ret; } +#endif static inline struct page *extent_buffer_page(struct extent_buffer *eb, unsigned long i) @@ -3163,13 +3165,21 @@ } } clear_page_dirty_for_io(page); +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) spin_lock_irq(&page->mapping->tree_lock); +#else + read_lock_irq(&page->mapping->tree_lock); +#endif if (!PageDirty(page)) { radix_tree_tag_clear(&page->mapping->page_tree, page_index(page), PAGECACHE_TAG_DIRTY); } +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) spin_unlock_irq(&page->mapping->tree_lock); +#else + read_unlock_irq(&page->mapping->tree_lock); +#endif unlock_page(page); } return 0; @@ -3347,7 +3357,11 @@ for (i = start_i; i < num_pages; i++) { page = extent_buffer_page(eb, i); if (!wait) { +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) if (!trylock_page(page)) +#else + if(!TestSetPageLocked(page)) +#endif goto unlock_exit; } else { lock_page(page); diff -Naur btrfs-orig/extent_io.h btrfs/extent_io.h --- btrfs-orig/extent_io.h 2009-02-20 12:10:15.000000000 -0500 +++ btrfs/extent_io.h 2009-02-20 12:11:30.000000000 -0500 @@ -2,6 +2,7 @@ #define __EXTENTIO__ #include <linux/rbtree.h> +#include <linux/version.h> /* bits for the extent state */ #define EXTENT_DIRTY 1 @@ -205,8 +206,10 @@ unsigned from, unsigned to); sector_t extent_bmap(struct address_space *mapping, sector_t iblock, get_extent_t *get_extent); +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29) int extent_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, __u64 start, __u64 len, get_extent_t *get_extent); +#endif int set_range_dirty(struct extent_io_tree *tree, u64 start, u64 end); int set_state_private(struct extent_io_tree *tree, u64 start, u64 private); int get_state_private(struct extent_io_tree *tree, u64 start, u64 *private); diff -Naur btrfs-orig/extent-tree.c btrfs/extent-tree.c --- btrfs-orig/extent-tree.c 2009-02-20 12:10:23.000000000 -0500 +++ btrfs/extent-tree.c 2009-02-20 12:15:27.000000000 -0500 @@ -20,7 +20,10 @@ #include <linux/writeback.h> #include <linux/blkdev.h> #include <linux/sort.h> +#include <linux/version.h> +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) #include <linux/ftrace.h> +#endif #include "compat.h" #include "hash.h" #include "crc32c.h" @@ -887,7 +890,11 @@ static void btrfs_issue_discard(struct block_device *bdev, u64 start, u64 len) { +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 28) blkdev_issue_discard(bdev, start >> 9, len >> 9, GFP_KERNEL); +#else + blkdev_issue_discard(bdev, start >> 9, len >> 9); +#endif } #endif diff -Naur btrfs-orig/file.c btrfs/file.c --- btrfs-orig/file.c 2009-02-20 12:10:24.000000000 -0500 +++ btrfs/file.c 2009-02-20 12:11:30.000000000 -0500 @@ -1044,7 +1044,11 @@ if (count == 0) goto out_nolock; +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) err = file_remove_suid(file); +#else + err = remove_suid(fdentry(file)); +#endif if (err) goto out_nolock; file_update_time(file); diff -Naur btrfs-orig/inode.c btrfs/inode.c --- btrfs-orig/inode.c 2009-02-20 12:10:23.000000000 -0500 +++ btrfs/inode.c 2009-02-20 12:11:30.000000000 -0500 @@ -3540,14 +3540,22 @@ if (objectid > root->highest_inode) root->highest_inode = objectid; +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) inode->i_uid = current_fsuid(); +#else + inode->i_uid = current->fsuid; +#endif if (dir && (dir->i_mode & S_ISGID)) { inode->i_gid = dir->i_gid; if (S_ISDIR(mode)) mode |= S_ISGID; } else +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) inode->i_gid = current_fsgid(); +#else + inode->i_gid = current->fsgid; +#endif inode->i_mode = mode; inode->i_ino = objectid; @@ -4248,11 +4256,13 @@ return -EINVAL; } +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29) static int btrfs_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo, __u64 start, __u64 len) { return extent_fiemap(inode, fieinfo, start, len, btrfs_get_extent); } +#endif int btrfs_readpage(struct file *file, struct page *page) { @@ -4584,7 +4594,11 @@ kmem_cache_free(btrfs_inode_cachep, BTRFS_I(inode)); } +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) static void init_once(void *foo) +#else +static void init_once(struct kmem_cache *bar, void *foo) +#endif { struct btrfs_inode *ei = (struct btrfs_inode *) foo; @@ -4607,7 +4621,12 @@ struct kmem_cache *btrfs_cache_create(const char *name, size_t size, unsigned long extra_flags, - void (*ctor)(void *)) +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) + void (*ctor)(void *) +#else + void (*ctor)(struct kmem_cache *, void*) +#endif +) { return kmem_cache_create(name, size, 0, (SLAB_RECLAIM_ACCOUNT | SLAB_MEM_SPREAD | extra_flags), ctor); @@ -5026,7 +5045,12 @@ return __set_page_dirty_nobuffers(page); } +#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 26) static int btrfs_permission(struct inode *inode, int mask) +#else +static int btrfs_permission(struct inode *inode, int mask, + struct nameidata *nd) +#endif { if (btrfs_test_flag(inode, READONLY) && (mask & MAY_WRITE)) return -EACCES; @@ -5120,7 +5144,9 @@ .removexattr = btrfs_removexattr, .permission = btrfs_permission, .fallocate = btrfs_fallocate, +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29) .fiemap = btrfs_fiemap, +#endif }; static struct inode_operations btrfs_special_inode_operations = { .getattr = btrfs_getattr, diff -Naur btrfs-orig/ioctl.c btrfs/ioctl.c --- btrfs-orig/ioctl.c 2009-02-20 12:10:23.000000000 -0500 +++ btrfs/ioctl.c 2009-02-20 12:11:30.000000000 -0500 @@ -240,7 +240,11 @@ return -EEXIST; if (IS_DEADDIR(dir)) return -ENOENT; +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) return inode_permission(dir, MAY_WRITE | MAY_EXEC); +#else + return permission(dir, MAY_WRITE | MAY_EXEC, NULL); +#endif } /* diff -Naur btrfs-orig/modules.order btrfs/modules.order --- btrfs-orig/modules.order 1969-12-31 19:00:00.000000000 -0500 +++ btrfs/modules.order 2009-02-20 12:17:02.000000000 -0500 @@ -0,0 +1 @@ +kernel//home/ltrager/btrfs/btrfs/btrfs.ko diff -Naur btrfs-orig/super.c btrfs/super.c --- btrfs-orig/super.c 2009-02-20 12:10:21.000000000 -0500 +++ btrfs/super.c 2009-02-20 12:11:30.000000000 -0500 @@ -38,6 +38,7 @@ #include <linux/namei.h> #include <linux/miscdevice.h> #include <linux/magic.h> +#include <linux/version.h> #include "compat.h" #include "ctree.h" #include "disk-io.h" @@ -51,6 +52,9 @@ #include "export.h" #include "compression.h" +#ifndef BTRFS_SUPER_MAGIC +#define BTRFS_SUPER_MAGIC 0x9123683E +#endif static struct super_operations btrfs_super_ops; @@ -609,6 +613,8 @@ return ret; } + +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29) static int btrfs_freeze(struct super_block *sb) { struct btrfs_root *root = btrfs_sb(sb); @@ -617,6 +623,7 @@ return 0; } + static int btrfs_unfreeze(struct super_block *sb) { struct btrfs_root *root = btrfs_sb(sb); @@ -625,6 +632,27 @@ return 0; } + +#else + + +static void btrfs_write_super_lockfs(struct super_block *sb) +{ + struct btrfs_root *root = btrfs_sb(sb); + mutex_lock(&root->fs_info->transaction_kthread_mutex); + mutex_lock(&root->fs_info->cleaner_mutex); +} + + +static void btrfs_unlockfs(struct super_block *sb) +{ + struct btrfs_root *root = btrfs_sb(sb); + mutex_unlock(&root->fs_info->cleaner_mutex); + mutex_unlock(&root->fs_info->transaction_kthread_mutex); +} +#endif + + static struct super_operations btrfs_super_ops = { .delete_inode = btrfs_delete_inode, .put_super = btrfs_put_super, @@ -637,8 +665,13 @@ .destroy_inode = btrfs_destroy_inode, .statfs = btrfs_statfs, .remount_fs = btrfs_remount, +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 29) .freeze_fs = btrfs_freeze, .unfreeze_fs = btrfs_unfreeze, +#else + .write_super_lockfs = btrfs_write_super_lockfs, + .unlockfs = btrfs_unlockfs, +#endif }; static const struct file_operations btrfs_ctl_fops = { -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
jim owens
2009-Feb-20 18:25 UTC
Re: [PATCH] Backport for 2.6.27 and 2.6.26 on the experimental branch
lee, A couple of thoughts about your .26 lockup: - I assume you are on the same hardware with 27. - Are you using a module or builtin btrfs (I build it in). - It looks like you are using vmware... when I''m doing kernel stuff I want to be on the iron, not trusting virtual machine code. (people who use vmware tell me they have to rebuild vmware stuff even when they apply kernel patch distro updates) - Compare your .26 and .27 configs, changes to default io sched or vm etc. can hurt or help you. jim -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Lee Trager
2009-Feb-23 22:23 UTC
Re: [PATCH] Backport for 2.6.27 and 2.6.26 on the experimental branch
On Fri, Feb 20, 2009 at 01:25:19PM -0500, jim owens wrote:> lee, > > A couple of thoughts about your .26 lockup: > > - I assume you are on the same hardware with 27.I am.> > - Are you using a module or builtin btrfs (I build it in). >As a module> - It looks like you are using vmware... when I''m doing kernel > stuff I want to be on the iron, not trusting virtual machine code. > (people who use vmware tell me they have to rebuild vmware stuff > even when they apply kernel patch distro updates)I tried running the same code(on 27 and 26) on a physical machine running Debian Lenny and ran into the same problem. So I don''t think its vmware.> > - Compare your .26 and .27 configs, changes to default io sched > or vm etc. can hurt or help you.I used the standard Debian Lenny 2.6.26 kernel for testing. For 2.6.27 I tested against the config for lenny found in the Debian svn. The only differences seems to be the new features.> > jimThe more and more I look at this problem the more I tend to think that the issue is because of some change in the way the VFS or something interacts with the file system. Does anyone know of any big changes? Why is the inode being marked dirty? Is there some kind of read error. I''m completly lost in solving this problem. Thanks for all your help, Lee -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
jim owens
2009-Feb-24 16:24 UTC
Re: [PATCH] Backport for 2.6.27 and 2.6.26 on the experimental branch
Lee Trager wrote:> The more and more I look at this problem the more I tend to think that > the issue is because of some change in the way the VFS or something > interacts with the file system. Does anyone know of any big changes? Why > is the inode being marked dirty? Is there some kind of read error. I''m > completly lost in solving this problem.Being a filesystem guy, I always try blaming vm or drivers :) Until someone with real experience gives us the answer, I''ll work with you off the mailing list to try to narrow down why this is happening. jim -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Lee Trager
2009-Feb-24 20:36 UTC
Re: [PATCH] Backport for 2.6.27 and 2.6.26 on the experimental branch
I ran a few tests that Jim suggested and found that btrfs works fine on 2.6.26 as long as there are only 23 or less files on the file system. Anymore and I experience the lockup. Jim and I will be working to find a solution but if anyone else has any clues that would be greatly appreciated. Lee On Tue, Feb 24, 2009 at 11:24:06AM -0500, jim owens wrote:> Lee Trager wrote: >> The more and more I look at this problem the more I tend to think that >> the issue is because of some change in the way the VFS or something >> interacts with the file system. Does anyone know of any big changes? Why >> is the inode being marked dirty? Is there some kind of read error. I''m >> completly lost in solving this problem. > > Being a filesystem guy, I always try blaming vm or drivers :) > > Until someone with real experience gives us the answer, > I''ll work with you off the mailing list to try to narrow > down why this is happening. > > jim-- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Lee Trager
2009-Feb-25 23:09 UTC
Re: [PATCH] Backport for 2.6.27 and 2.6.26 on the experimental branch
A second update to this. It seems the problem is that btrfs gets stuck in an infinite loop while in tree_insert. I''m not sure why yet. Below is my back trace incase anyone wants to have a look. [ 9824.393942] SysRq : Show Blocked State [ 9824.393942] task PC stack pid father [ 9824.393942] ls D 00000000 0 3456 3334 [ 9824.393942] f1ada8c0 00200082 01c19000 00000000 01c19000 f1adaa4c c27f7fa0 00000000 [ 9824.393942] f518830c 001f711e c27e68a4 c013604c 00000000 00000000 00000000 000000ff [ 9824.393942] c27f7fa0 0243d000 c27e68a4 c015688a c02b8498 f1b6fc64 f1b6fc64 c01568bd [ 9824.393942] Call Trace: [ 9824.393942] [<c013604c>] getnstimeofday+0x37/0xbc [ 9824.393942] [<c015688a>] sync_page+0x0/0x36 [ 9824.393942] [<c02b8498>] io_schedule+0x49/0x80 [ 9824.393942] [<c01568bd>] sync_page+0x33/0x36 [ 9824.393942] [<c02b85c4>] __wait_on_bit_lock+0x2a/0x52 [ 9824.393942] [<c015687c>] __lock_page+0x4e/0x54 [ 9824.393942] [<c0131909>] wake_bit_function+0x0/0x3c [ 9824.393942] [<f8f9d2da>] read_extent_buffer_pages+0x133/0x2f1 [btrfs] [ 9824.393942] [<f8f820b4>] btree_read_extent_buffer_pages+0x39/0x8c [btrfs] [ 9824.393942] [<f8f83d9d>] btree_get_extent+0x0/0x173 [btrfs] [ 9824.393942] [<f8f823ba>] read_tree_block+0x29/0x4c [btrfs] [ 9824.393942] [<f8f72336>] btrfs_search_slot+0x4fe/0x638 [btrfs] [ 9824.393942] [<f8f8186b>] btrfs_lookup_inode+0x27/0x88 [btrfs] [ 9824.393942] [<f8f87bce>] btrfs_read_locked_inode+0x53/0x2fc [btrfs] [ 9824.393942] [<c018485c>] iget5_locked+0x7a/0x12b [ 9824.393942] [<f8f89acf>] btrfs_find_actor+0x0/0x27 [btrfs] [ 9824.393942] [<f8f87ebd>] btrfs_iget+0x46/0x6c [btrfs] [ 9824.393942] [<f8f88056>] btrfs_lookup_dentry+0x173/0x184 [btrfs] [ 9824.393942] [<c0183039>] d_alloc+0x138/0x17a [ 9824.393942] [<f8f89e90>] btrfs_lookup+0x18/0x2d [btrfs] [ 9824.393942] [<c017a53b>] do_lookup+0xb6/0x153 [ 9824.393942] [<c017c12d>] __link_path_walk+0x724/0xb0b [ 9824.393942] [<f8f9ac63>] tree_insert+0x54/0x5b [btrfs] [ 9824.393942] [<c017c54b>] path_walk+0x37/0x70 [ 9824.393942] [<c017c7fa>] do_path_lookup+0x122/0x184 [ 9824.393942] [<c017d057>] __user_walk_fd+0x29/0x3a [ 9824.393942] [<c0177141>] vfs_lstat_fd+0x12/0x39 [ 9824.393942] [<c01771d5>] sys_lstat64+0xf/0x23 [ 9824.393942] [<c0103853>] sysenter_past_esp+0x78/0xb1 [ 9824.393942] [<c02b0000>] acpi_pci_root_add+0x125/0x296 [ 9824.393942] ======================[ 9824.393942] Sched Debug Version: v0.07, 2.6.26-1-686 #1 [ 9824.393942] now at 8542803.745635 msecs [ 9824.393942] .sysctl_sched_latency : 40.000000 [ 9824.393942] .sysctl_sched_min_granularity : 8.000000 [ 9824.393942] .sysctl_sched_wakeup_granularity : 20.000000 [ 9824.393942] .sysctl_sched_child_runs_first : 0.000001 [ 9824.393942] .sysctl_sched_features : 895 [ 9824.393942] [ 9824.393942] cpu#0, 1862.040 MHz [ 9824.393942] .nr_running : 2 [ 9824.393942] .load : 2048 [ 9824.393942] .nr_switches : 475330 [ 9824.393942] .nr_load_updates : 61723 [ 9824.393942] .nr_uninterruptible : 4294966907 [ 9824.393942] .jiffies : 2060701 [ 9824.393942] .next_balance : 2.060723 [ 9824.393942] .curr->pid : 2199 [ 9824.393942] .clock : 8542803.113648 [ 9824.393942] .cpu_load[0] : 0 [ 9824.393942] .cpu_load[1] : 175 [ 9824.393942] .cpu_load[2] : 469 [ 9824.393942] .cpu_load[3] : 621 [ 9824.393942] .cpu_load[4] : 542 [ 9824.393942] [ 9824.393942] cfs_rq[0]: [ 9824.393942] .exec_clock : 0.000000 [ 9824.393942] .MIN_vruntime : 179538.548824 [ 9824.393942] .min_vruntime : 179578.548817 [ 9824.393942] .max_vruntime : 179538.548824 [ 9824.393942] .spread : 0.000000 [ 9824.393942] .spread0 : 0.000000 [ 9824.393942] .nr_running : 2 [ 9824.393942] .load : 2048 [ 9824.393942] .nr_spread_over : 0 [ 9824.393942] [ 9824.393942] runnable tasks: [ 9824.393942] task PID tree-key switches prio exec-runtime sum-exec sum-sleep [ 9824.393942] ---------------------------------------------------------------------------------------------------------- [ 9824.393942] R rsyslogd 2199 179538.548820 28 120 0 0 0.000000 0.000000 0.000000 / [ 9824.393942] rsyslogd 3333 179538.548824 9 120 0 0 0.000000 0.000000 0.000000 / [ 9824.393942] [ 9824.393942] cpu#1, 1862.040 MHz [ 9824.393942] .nr_running : 2 [ 9824.393942] .load : 2048 [ 9824.393942] .nr_switches : 90067 [ 9824.393942] .nr_load_updates : 31570 [ 9824.393942] .nr_uninterruptible : 390 [ 9824.393942] .jiffies : 2060701 [ 9824.393942] .next_balance : 2.060674 [ 9824.393942] .curr->pid : 3450 [ 9824.393942] .clock : 8542801.036413 [ 9824.393942] .cpu_load[0] : 0 [ 9824.393942] .cpu_load[1] : 0 [ 9824.393942] .cpu_load[2] : 20 [ 9824.393942] .cpu_load[3] : 56 [ 9824.393942] .cpu_load[4] : 60 [ 9824.393942] [ 9824.393942] cfs_rq[1]: [ 9824.393942] .exec_clock : 0.000000 [ 9824.393942] .MIN_vruntime : 40916.410301 [ 9824.393942] .min_vruntime : 40926.274857 [ 9824.393942] .max_vruntime : 40916.410301 [ 9824.393942] .spread : 0.000000 [ 9824.393942] .spread0 : -138652.273960 [ 9824.393942] .nr_running : 2 [ 9824.393942] .load : 2048 [ 9824.393942] .nr_spread_over : 0 [ 9824.393942] [ 9824.393942] runnable tasks: [ 9824.393942] task PID tree-key switches prio exec-runtime sum-exec sum-sleep [ 9824.393942] ---------------------------------------------------------------------------------------------------------- [ 9824.393942] metacity 3176 40916.410301 2904 120 0 0 0.000000 0.000000 0.000000 / [ 9824.393942] R bash 3450 40886.274880 34 120 0 0 0.000000 0.000000 0.000000 / [ 9824.393942] Lee On Tue, Feb 24, 2009 at 03:36:29PM -0500, Lee Trager wrote:> I ran a few tests that Jim suggested and found that btrfs works fine on > 2.6.26 as long as there are only 23 or less files on the file system. > Anymore and I experience the lockup. Jim and I will be working to find a > solution but if anyone else has any clues that would be greatly > appreciated. > > Lee > On Tue, Feb 24, 2009 at 11:24:06AM -0500, jim owens wrote: > > Lee Trager wrote: > >> The more and more I look at this problem the more I tend to think that > >> the issue is because of some change in the way the VFS or something > >> interacts with the file system. Does anyone know of any big changes? Why > >> is the inode being marked dirty? Is there some kind of read error. I''m > >> completly lost in solving this problem. > > > > Being a filesystem guy, I always try blaming vm or drivers :) > > > > Until someone with real experience gives us the answer, > > I''ll work with you off the mailing list to try to narrow > > down why this is happening. > > > > jim > -- > To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html-- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html