diff options
author | Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com> | 2012-06-26 04:51:55 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-07-09 14:31:16 -0400 |
commit | b71f3bcc5ab5e76a22d7ad82b3795602fcf0e0af (patch) | |
tree | e20b14153cd36a3c50d1c652e6e733a00e79f800 /drivers/staging/zcache | |
parent | 79c0d92c5b6175c1462fbe38bf44180f325aa478 (diff) |
staging: zcache: cleanup zcache_do_preload and zcache_put_page
Cleanup the code for zcache_do_preload and zcache_put_page
Acked-by: Seth Jennings <sjenning@linux.vnet.ibm.com>
Signed-off-by: Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com>
Acked-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/staging/zcache')
-rw-r--r-- | drivers/staging/zcache/zcache-main.c | 37 |
1 files changed, 16 insertions, 21 deletions
diff --git a/drivers/staging/zcache/zcache-main.c b/drivers/staging/zcache/zcache-main.c index 57e25fc6745..fbd9bcfa9d9 100644 --- a/drivers/staging/zcache/zcache-main.c +++ b/drivers/staging/zcache/zcache-main.c | |||
@@ -1045,29 +1045,24 @@ static int zcache_do_preload(struct tmem_pool *pool) | |||
1045 | kp->objnodes[kp->nr++] = objnode; | 1045 | kp->objnodes[kp->nr++] = objnode; |
1046 | } | 1046 | } |
1047 | 1047 | ||
1048 | obj = kmem_cache_alloc(zcache_obj_cache, ZCACHE_GFP_MASK); | 1048 | if (!kp->obj) { |
1049 | if (unlikely(obj == NULL)) { | 1049 | obj = kmem_cache_alloc(zcache_obj_cache, ZCACHE_GFP_MASK); |
1050 | zcache_failed_alloc++; | 1050 | if (unlikely(obj == NULL)) { |
1051 | goto out; | 1051 | zcache_failed_alloc++; |
1052 | goto out; | ||
1053 | } | ||
1054 | kp->obj = obj; | ||
1052 | } | 1055 | } |
1053 | 1056 | ||
1054 | page = (void *)__get_free_page(ZCACHE_GFP_MASK); | 1057 | if (!kp->page) { |
1055 | if (unlikely(page == NULL)) { | 1058 | page = (void *)__get_free_page(ZCACHE_GFP_MASK); |
1056 | zcache_failed_get_free_pages++; | 1059 | if (unlikely(page == NULL)) { |
1057 | kmem_cache_free(zcache_obj_cache, obj); | 1060 | zcache_failed_get_free_pages++; |
1058 | goto out; | 1061 | goto out; |
1062 | } | ||
1063 | kp->page = page; | ||
1059 | } | 1064 | } |
1060 | 1065 | ||
1061 | if (kp->obj == NULL) | ||
1062 | kp->obj = obj; | ||
1063 | else | ||
1064 | kmem_cache_free(zcache_obj_cache, obj); | ||
1065 | |||
1066 | if (kp->page == NULL) | ||
1067 | kp->page = page; | ||
1068 | else | ||
1069 | free_page((unsigned long)page); | ||
1070 | |||
1071 | ret = 0; | 1066 | ret = 0; |
1072 | out: | 1067 | out: |
1073 | return ret; | 1068 | return ret; |
@@ -1577,14 +1572,14 @@ static int zcache_put_page(int cli_id, int pool_id, struct tmem_oid *oidp, | |||
1577 | else | 1572 | else |
1578 | zcache_failed_pers_puts++; | 1573 | zcache_failed_pers_puts++; |
1579 | } | 1574 | } |
1580 | zcache_put_pool(pool); | ||
1581 | } else { | 1575 | } else { |
1582 | zcache_put_to_flush++; | 1576 | zcache_put_to_flush++; |
1583 | if (atomic_read(&pool->obj_count) > 0) | 1577 | if (atomic_read(&pool->obj_count) > 0) |
1584 | /* the put fails whether the flush succeeds or not */ | 1578 | /* the put fails whether the flush succeeds or not */ |
1585 | (void)tmem_flush_page(pool, oidp, index); | 1579 | (void)tmem_flush_page(pool, oidp, index); |
1586 | zcache_put_pool(pool); | ||
1587 | } | 1580 | } |
1581 | |||
1582 | zcache_put_pool(pool); | ||
1588 | out: | 1583 | out: |
1589 | return ret; | 1584 | return ret; |
1590 | } | 1585 | } |