xen/blkback: Use kzalloc's, and GFP_KERNEL for data structures.
The patch titled:"xen/blkback: Use 'vzalloc' for page arrays and pre-allocate pages." allocates the structures and its member variables using the 'vzalloc'. Daniel Stodden pointed out that vzalloc is good when we use big number of pages - while these are at the max two pages. We can do this using kzalloc. Also the GFP_HIGHMEM does not work properly with Xen, so take that out. We will have to revisit this when a "get_empty_pages_and_pagevec" type API shows up to leverage that. BugLink: http://mid.gmane.org/1299898639.11681.227.camel@agari.van.xensource.com CC: Daniel Stodden <daniel.stodden@citrix.com> Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
This commit is contained in:
parent
5dc03639cc
commit
a742b02c75
|
@ -642,7 +642,7 @@ static int __init blkif_init(void)
|
||||||
if (!xen_pv_domain())
|
if (!xen_pv_domain())
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
blkbk = (struct xen_blkbk *)vmalloc(sizeof(struct xen_blkbk));
|
blkbk = (struct xen_blkbk *)kzalloc(sizeof(struct xen_blkbk), GFP_KERNEL);
|
||||||
if (!blkbk) {
|
if (!blkbk) {
|
||||||
printk(KERN_ALERT "%s: out of memory!\n", __func__);
|
printk(KERN_ALERT "%s: out of memory!\n", __func__);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
@ -652,9 +652,10 @@ static int __init blkif_init(void)
|
||||||
|
|
||||||
blkbk->pending_reqs = kmalloc(sizeof(blkbk->pending_reqs[0]) *
|
blkbk->pending_reqs = kmalloc(sizeof(blkbk->pending_reqs[0]) *
|
||||||
blkif_reqs, GFP_KERNEL);
|
blkif_reqs, GFP_KERNEL);
|
||||||
blkbk->pending_grant_handles = vzalloc(sizeof(blkbk->pending_grant_handles[0]) *
|
blkbk->pending_grant_handles = kzalloc(sizeof(blkbk->pending_grant_handles[0]) *
|
||||||
mmap_pages);
|
mmap_pages, GFP_KERNEL);
|
||||||
blkbk->pending_pages = vzalloc(sizeof(blkbk->pending_pages[0]) * mmap_pages);
|
blkbk->pending_pages = kzalloc(sizeof(blkbk->pending_pages[0]) *
|
||||||
|
mmap_pages, GFP_KERNEL);
|
||||||
|
|
||||||
if (!blkbk->pending_reqs || !blkbk->pending_grant_handles || !blkbk->pending_pages) {
|
if (!blkbk->pending_reqs || !blkbk->pending_grant_handles || !blkbk->pending_pages) {
|
||||||
rc = -ENOMEM;
|
rc = -ENOMEM;
|
||||||
|
@ -663,7 +664,7 @@ static int __init blkif_init(void)
|
||||||
|
|
||||||
for (i = 0; i < mmap_pages; i++) {
|
for (i = 0; i < mmap_pages; i++) {
|
||||||
blkbk->pending_grant_handles[i] = BLKBACK_INVALID_HANDLE;
|
blkbk->pending_grant_handles[i] = BLKBACK_INVALID_HANDLE;
|
||||||
blkbk->pending_pages[i] = alloc_page(GFP_KERNEL | __GFP_HIGHMEM);
|
blkbk->pending_pages[i] = alloc_page(GFP_KERNEL);
|
||||||
if (blkbk->pending_pages[i] == NULL) {
|
if (blkbk->pending_pages[i] == NULL) {
|
||||||
rc = -ENOMEM;
|
rc = -ENOMEM;
|
||||||
goto out_of_memory;
|
goto out_of_memory;
|
||||||
|
@ -692,13 +693,13 @@ static int __init blkif_init(void)
|
||||||
printk(KERN_ERR "%s: out of memory\n", __func__);
|
printk(KERN_ERR "%s: out of memory\n", __func__);
|
||||||
failed_init:
|
failed_init:
|
||||||
kfree(blkbk->pending_reqs);
|
kfree(blkbk->pending_reqs);
|
||||||
vfree(blkbk->pending_grant_handles);
|
kfree(blkbk->pending_grant_handles);
|
||||||
for (i = 0; i < mmap_pages; i++) {
|
for (i = 0; i < mmap_pages; i++) {
|
||||||
if (blkbk->pending_pages[i])
|
if (blkbk->pending_pages[i])
|
||||||
__free_page(blkbk->pending_pages[i]);
|
__free_page(blkbk->pending_pages[i]);
|
||||||
}
|
}
|
||||||
vfree(blkbk->pending_pages);
|
kfree(blkbk->pending_pages);
|
||||||
vfree(blkbk);
|
kfree(blkbk);
|
||||||
blkbk = NULL;
|
blkbk = NULL;
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue