Change vmalloc in metadata asynch io to kmalloc
Vmalloc is very slow in comparison to kmalloc Signed-off-by: Jan Musial <jan.musial@intel.com>
This commit is contained in:
parent
9f8802e833
commit
b47ef2c386
@ -301,7 +301,7 @@ void metadata_io_req_finalize(struct metadata_io_request *m_req)
|
||||
struct metadata_io_request_asynch *a_req = m_req->asynch;
|
||||
|
||||
if (env_atomic_dec_return(&a_req->req_active) == 0)
|
||||
env_vfree(a_req);
|
||||
env_free(a_req);
|
||||
}
|
||||
|
||||
static uint32_t metadata_io_max_page(ocf_cache_t cache)
|
||||
@ -379,7 +379,7 @@ static int metadata_io_i_asynch(ocf_cache_t cache, ocf_queue_t queue, int dir,
|
||||
if (count == 0)
|
||||
return 0;
|
||||
|
||||
a_req = env_vzalloc_flags(sizeof(*a_req), ENV_MEM_NOIO);
|
||||
a_req = env_zalloc(sizeof(*a_req), ENV_MEM_NOIO);
|
||||
if (!a_req)
|
||||
return -OCF_ERR_NO_MEM;
|
||||
|
||||
@ -427,14 +427,14 @@ static int metadata_io_i_asynch(ocf_cache_t cache, ocf_queue_t queue, int dir,
|
||||
compl_hndl(cache, context, a_req->error);
|
||||
|
||||
if (env_atomic_dec_return(&a_req->req_active) == 0)
|
||||
env_vfree(a_req);
|
||||
env_free(a_req);
|
||||
|
||||
return 0;
|
||||
|
||||
err:
|
||||
while (i--)
|
||||
ctx_data_free(cache->owner, a_req->reqs[i].data);
|
||||
env_vfree(a_req);
|
||||
env_free(a_req);
|
||||
|
||||
return -OCF_ERR_NO_MEM;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user