aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/jbd/journal.c11
-rw-r--r--fs/jbd/transaction.c4
-rw-r--r--include/linux/jbd.h6
3 files changed, 3 insertions, 18 deletions
diff --git a/fs/jbd/journal.c b/fs/jbd/journal.c
index 7edf3fdfdadd..65c290470664 100644
--- a/fs/jbd/journal.c
+++ b/fs/jbd/journal.c
@@ -653,7 +653,7 @@ static journal_t * journal_init_common (void)
653 journal_t *journal; 653 journal_t *journal;
654 int err; 654 int err;
655 655
656 journal = jbd_kmalloc(sizeof(*journal), GFP_KERNEL); 656 journal = kmalloc(sizeof(*journal), GFP_KERNEL);
657 if (!journal) 657 if (!journal)
658 goto fail; 658 goto fail;
659 memset(journal, 0, sizeof(*journal)); 659 memset(journal, 0, sizeof(*journal));
@@ -1607,15 +1607,6 @@ int journal_blocks_per_page(struct inode *inode)
1607} 1607}
1608 1608
1609/* 1609/*
1610 * Simple support for retrying memory allocations. Introduced to help to
1611 * debug different VM deadlock avoidance strategies.
1612 */
1613void * __jbd_kmalloc (const char *where, size_t size, gfp_t flags, int retry)
1614{
1615 return kmalloc(size, flags | (retry ? __GFP_NOFAIL : 0));
1616}
1617
1618/*
1619 * Journal_head storage management 1610 * Journal_head storage management
1620 */ 1611 */
1621static struct kmem_cache *journal_head_cache; 1612static struct kmem_cache *journal_head_cache;
diff --git a/fs/jbd/transaction.c b/fs/jbd/transaction.c
index db8404514c92..0282deb8ff2d 100644
--- a/fs/jbd/transaction.c
+++ b/fs/jbd/transaction.c
@@ -96,8 +96,8 @@ static int start_this_handle(journal_t *journal, handle_t *handle)
96 96
97alloc_transaction: 97alloc_transaction:
98 if (!journal->j_running_transaction) { 98 if (!journal->j_running_transaction) {
99 new_transaction = jbd_kmalloc(sizeof(*new_transaction), 99 new_transaction = kmalloc(sizeof(*new_transaction),
100 GFP_NOFS); 100 GFP_NOFS|__GFP_NOFAIL);
101 if (!new_transaction) { 101 if (!new_transaction) {
102 ret = -ENOMEM; 102 ret = -ENOMEM;
103 goto out; 103 goto out;
diff --git a/include/linux/jbd.h b/include/linux/jbd.h
index 1db3b684f557..a3abf51e488f 100644
--- a/include/linux/jbd.h
+++ b/include/linux/jbd.h
@@ -72,12 +72,6 @@ extern int journal_enable_debug;
72#define jbd_debug(f, a...) /**/ 72#define jbd_debug(f, a...) /**/
73#endif 73#endif
74 74
75extern void * __jbd_kmalloc (const char *where, size_t size, gfp_t flags, int retry);
76#define jbd_kmalloc(size, flags) \
77 __jbd_kmalloc(__FUNCTION__, (size), (flags), journal_oom_retry)
78#define jbd_rep_kmalloc(size, flags) \
79 __jbd_kmalloc(__FUNCTION__, (size), (flags), 1)
80
81static inline void *jbd_alloc(size_t size, gfp_t flags) 75static inline void *jbd_alloc(size_t size, gfp_t flags)
82{ 76{
83 return (void *)__get_free_pages(flags, get_order(size)); 77 return (void *)__get_free_pages(flags, get_order(size));