diff options
author | David Sterba <dsterba@suse.cz> | 2012-01-26 21:01:12 +0100 |
---|---|---|
committer | David Sterba <dsterba@suse.cz> | 2012-02-15 16:40:25 +0100 |
commit | c08782dacd7a098f2b8bca7f4a57a5b402e9e1e5 (patch) | |
tree | f86a4875ac874cd3ddd0cc2eae85701e87105a72 | |
parent | btrfs: delalloc for page dirtied out-of-band in fixup worker (diff) | |
download | linux-c08782dacd7a098f2b8bca7f4a57a5b402e9e1e5.tar.xz linux-c08782dacd7a098f2b8bca7f4a57a5b402e9e1e5.zip |
btrfs: fix structs where bitfields and spinlock/atomic share 8B word
On ia64, powerpc64 and sparc64 the bitfield is modified through a RMW cycle and current
gcc rewrites the adjacent 4B word, which in case of a spinlock or atomic has
disaterous effect.
https://lkml.org/lkml/2012/2/1/220
Signed-off-by: David Sterba <dsterba@suse.cz>
-rw-r--r-- | fs/btrfs/ctree.h | 2 | ||||
-rw-r--r-- | fs/btrfs/extent_map.h | 4 |
2 files changed, 3 insertions, 3 deletions
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index 3c2cbf7b6663..8e4457e0478e 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h @@ -886,7 +886,7 @@ struct btrfs_block_rsv { u64 reserved; struct btrfs_space_info *space_info; spinlock_t lock; - unsigned int full:1; + unsigned int full; }; /* diff --git a/fs/btrfs/extent_map.h b/fs/btrfs/extent_map.h index 33a7890b1f40..1195f09761fe 100644 --- a/fs/btrfs/extent_map.h +++ b/fs/btrfs/extent_map.h @@ -26,8 +26,8 @@ struct extent_map { unsigned long flags; struct block_device *bdev; atomic_t refs; - unsigned int in_tree:1; - unsigned int compress_type:4; + unsigned int in_tree; + unsigned int compress_type; }; struct extent_map_tree { |