diff options
author | Joern Engel <joern@logfs.org> | 2010-04-15 02:03:57 -0400 |
---|---|---|
committer | Joern Engel <joern@logfs.org> | 2010-04-15 02:03:57 -0400 |
commit | 1f1b0008e8dd1930d6e89522c70f4a438374302a (patch) | |
tree | fb35404bdb4db79925891779e3be118eca8e85dd /fs/logfs | |
parent | ead88af5f577fd2b399a0fcdfe52605116fac489 (diff) |
[LogFS] Prevent mempool_destroy NULL pointer dereference
It would probably be better to just accept NULL pointers in
mempool_destroy(). But for the current -rc series let's keep things
simple.
This patch was lost in the cracks for a while.
Kevin Cernekee <cernekee@gmail.com> had to rediscover the problem and
send a similar patch because of it. :(
Signed-off-by: Joern Engel <joern@logfs.org>
Diffstat (limited to 'fs/logfs')
-rw-r--r-- | fs/logfs/logfs.h | 6 | ||||
-rw-r--r-- | fs/logfs/readwrite.c | 6 | ||||
-rw-r--r-- | fs/logfs/segment.c | 2 | ||||
-rw-r--r-- | fs/logfs/super.c | 4 |
4 files changed, 11 insertions, 7 deletions
diff --git a/fs/logfs/logfs.h b/fs/logfs/logfs.h index c9929eed80b1..0a3df1a0c936 100644 --- a/fs/logfs/logfs.h +++ b/fs/logfs/logfs.h | |||
@@ -727,4 +727,10 @@ static inline struct logfs_area *get_area(struct super_block *sb, | |||
727 | return logfs_super(sb)->s_area[(__force u8)gc_level]; | 727 | return logfs_super(sb)->s_area[(__force u8)gc_level]; |
728 | } | 728 | } |
729 | 729 | ||
730 | static inline void logfs_mempool_destroy(mempool_t *pool) | ||
731 | { | ||
732 | if (pool) | ||
733 | mempool_destroy(pool); | ||
734 | } | ||
735 | |||
730 | #endif | 736 | #endif |
diff --git a/fs/logfs/readwrite.c b/fs/logfs/readwrite.c index 7e0c39c49719..aca6c56a107a 100644 --- a/fs/logfs/readwrite.c +++ b/fs/logfs/readwrite.c | |||
@@ -2243,8 +2243,6 @@ void logfs_cleanup_rw(struct super_block *sb) | |||
2243 | struct logfs_super *super = logfs_super(sb); | 2243 | struct logfs_super *super = logfs_super(sb); |
2244 | 2244 | ||
2245 | destroy_meta_inode(super->s_segfile_inode); | 2245 | destroy_meta_inode(super->s_segfile_inode); |
2246 | if (super->s_block_pool) | 2246 | logfs_mempool_destroy(super->s_block_pool); |
2247 | mempool_destroy(super->s_block_pool); | 2247 | logfs_mempool_destroy(super->s_shadow_pool); |
2248 | if (super->s_shadow_pool) | ||
2249 | mempool_destroy(super->s_shadow_pool); | ||
2250 | } | 2248 | } |
diff --git a/fs/logfs/segment.c b/fs/logfs/segment.c index 02db22ebbf13..8c82fe05d3e1 100644 --- a/fs/logfs/segment.c +++ b/fs/logfs/segment.c | |||
@@ -912,7 +912,7 @@ err: | |||
912 | for (i--; i >= 0; i--) | 912 | for (i--; i >= 0; i--) |
913 | free_area(super->s_area[i]); | 913 | free_area(super->s_area[i]); |
914 | free_area(super->s_journal_area); | 914 | free_area(super->s_journal_area); |
915 | mempool_destroy(super->s_alias_pool); | 915 | logfs_mempool_destroy(super->s_alias_pool); |
916 | return -ENOMEM; | 916 | return -ENOMEM; |
917 | } | 917 | } |
918 | 918 | ||
diff --git a/fs/logfs/super.c b/fs/logfs/super.c index d6e1f4fc3115..d4531eb46d0a 100644 --- a/fs/logfs/super.c +++ b/fs/logfs/super.c | |||
@@ -517,8 +517,8 @@ static void logfs_kill_sb(struct super_block *sb) | |||
517 | if (super->s_erase_page) | 517 | if (super->s_erase_page) |
518 | __free_page(super->s_erase_page); | 518 | __free_page(super->s_erase_page); |
519 | super->s_devops->put_device(sb); | 519 | super->s_devops->put_device(sb); |
520 | mempool_destroy(super->s_btree_pool); | 520 | logfs_mempool_destroy(super->s_btree_pool); |
521 | mempool_destroy(super->s_alias_pool); | 521 | logfs_mempool_destroy(super->s_alias_pool); |
522 | kfree(super); | 522 | kfree(super); |
523 | log_super("LogFS: Finished unmounting\n"); | 523 | log_super("LogFS: Finished unmounting\n"); |
524 | } | 524 | } |