Commit 4c9a7d6a authored by Nadav Amit's avatar Nadav Amit Committed by Greg Kroah-Hartman

vmw_balloon: merge send_lock and send_unlock path

The lock and unlock code paths are very similar, so avoid the duplicate
code by merging them together.
Reviewed-by: default avatarXavier Deguillard <xdeguillard@vmware.com>
Signed-off-by: default avatarNadav Amit <namit@vmware.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 68131184
...@@ -420,16 +420,18 @@ static bool vmballoon_send_get_target(struct vmballoon *b) ...@@ -420,16 +420,18 @@ static bool vmballoon_send_get_target(struct vmballoon *b)
* check the return value and maybe submit a different page. * check the return value and maybe submit a different page.
*/ */
static int vmballoon_send_lock_page(struct vmballoon *b, unsigned long pfn, static int vmballoon_send_lock_page(struct vmballoon *b, unsigned long pfn,
unsigned int *hv_status) unsigned int *hv_status, bool lock)
{ {
unsigned long status; unsigned long status, cmd;
u32 pfn32; u32 pfn32;
pfn32 = (u32)pfn; pfn32 = (u32)pfn;
if (pfn32 != pfn) if (pfn32 != pfn)
return -EINVAL; return -EINVAL;
*hv_status = status = vmballoon_cmd(b, VMW_BALLOON_CMD_LOCK, pfn, 0); cmd = lock ? VMW_BALLOON_CMD_LOCK : VMW_BALLOON_CMD_UNLOCK;
*hv_status = status = vmballoon_cmd(b, cmd, pfn, 0);
if (status == VMW_BALLOON_SUCCESS) if (status == VMW_BALLOON_SUCCESS)
return 0; return 0;
...@@ -438,13 +440,18 @@ static int vmballoon_send_lock_page(struct vmballoon *b, unsigned long pfn, ...@@ -438,13 +440,18 @@ static int vmballoon_send_lock_page(struct vmballoon *b, unsigned long pfn,
} }
static int vmballoon_send_batched_lock(struct vmballoon *b, static int vmballoon_send_batched_lock(struct vmballoon *b,
unsigned int num_pages, bool is_2m_pages) unsigned int num_pages, bool is_2m_pages,
bool lock)
{ {
unsigned long pfn = PHYS_PFN(virt_to_phys(b->batch_page)); unsigned long pfn = PHYS_PFN(virt_to_phys(b->batch_page));
unsigned long status, cmd; unsigned long status, cmd;
if (lock)
cmd = is_2m_pages ? VMW_BALLOON_CMD_BATCHED_2M_LOCK : cmd = is_2m_pages ? VMW_BALLOON_CMD_BATCHED_2M_LOCK :
VMW_BALLOON_CMD_BATCHED_LOCK; VMW_BALLOON_CMD_BATCHED_LOCK;
else
cmd = is_2m_pages ? VMW_BALLOON_CMD_BATCHED_2M_UNLOCK :
VMW_BALLOON_CMD_BATCHED_UNLOCK;
status = vmballoon_cmd(b, cmd, pfn, num_pages); status = vmballoon_cmd(b, cmd, pfn, num_pages);
...@@ -454,37 +461,6 @@ static int vmballoon_send_batched_lock(struct vmballoon *b, ...@@ -454,37 +461,6 @@ static int vmballoon_send_batched_lock(struct vmballoon *b,
return 1; return 1;
} }
/*
* Notify the host that guest intends to release given page back into
* the pool of available (to the guest) pages.
*/
static bool vmballoon_send_unlock_page(struct vmballoon *b, unsigned long pfn)
{
unsigned long status;
u32 pfn32;
pfn32 = (u32)pfn;
if (pfn32 != pfn)
return false;
status = vmballoon_cmd(b, VMW_BALLOON_CMD_UNLOCK, pfn, 0);
return status == VMW_BALLOON_SUCCESS;
}
static bool vmballoon_send_batched_unlock(struct vmballoon *b,
unsigned int num_pages, bool is_2m_pages)
{
unsigned long pfn = PHYS_PFN(virt_to_phys(b->batch_page));
unsigned long status, cmd;
cmd = is_2m_pages ? VMW_BALLOON_CMD_BATCHED_2M_UNLOCK :
VMW_BALLOON_CMD_BATCHED_UNLOCK;
status = vmballoon_cmd(b, cmd, pfn, num_pages);
return status == VMW_BALLOON_SUCCESS;
}
static struct page *vmballoon_alloc_page(gfp_t flags, bool is_2m_page) static struct page *vmballoon_alloc_page(gfp_t flags, bool is_2m_page)
{ {
if (is_2m_page) if (is_2m_page)
...@@ -546,7 +522,8 @@ static int vmballoon_lock_page(struct vmballoon *b, unsigned int num_pages, ...@@ -546,7 +522,8 @@ static int vmballoon_lock_page(struct vmballoon *b, unsigned int num_pages,
/* is_2m_pages can never happen as 2m pages support implies batching */ /* is_2m_pages can never happen as 2m pages support implies batching */
locked = vmballoon_send_lock_page(b, page_to_pfn(page), &hv_status); locked = vmballoon_send_lock_page(b, page_to_pfn(page), &hv_status,
true);
if (locked) { if (locked) {
STATS_INC(b->stats.refused_alloc[false]); STATS_INC(b->stats.refused_alloc[false]);
...@@ -587,7 +564,7 @@ static int vmballoon_lock_batched_page(struct vmballoon *b, ...@@ -587,7 +564,7 @@ static int vmballoon_lock_batched_page(struct vmballoon *b,
int locked, i; int locked, i;
u16 size_per_page = vmballoon_page_size(is_2m_pages); u16 size_per_page = vmballoon_page_size(is_2m_pages);
locked = vmballoon_send_batched_lock(b, num_pages, is_2m_pages); locked = vmballoon_send_batched_lock(b, num_pages, is_2m_pages, true);
if (locked > 0) { if (locked > 0) {
for (i = 0; i < num_pages; i++) { for (i = 0; i < num_pages; i++) {
...@@ -645,10 +622,12 @@ static int vmballoon_unlock_page(struct vmballoon *b, unsigned int num_pages, ...@@ -645,10 +622,12 @@ static int vmballoon_unlock_page(struct vmballoon *b, unsigned int num_pages,
{ {
struct page *page = b->page; struct page *page = b->page;
struct vmballoon_page_size *page_size = &b->page_sizes[false]; struct vmballoon_page_size *page_size = &b->page_sizes[false];
unsigned int hv_status;
/* is_2m_pages can never happen as 2m pages support implies batching */ /* is_2m_pages can never happen as 2m pages support implies batching */
if (!vmballoon_send_unlock_page(b, page_to_pfn(page))) { if (!vmballoon_send_lock_page(b, page_to_pfn(page), &hv_status,
false)) {
list_add(&page->lru, &page_size->pages); list_add(&page->lru, &page_size->pages);
return -EIO; return -EIO;
} }
...@@ -670,7 +649,8 @@ static int vmballoon_unlock_batched_page(struct vmballoon *b, ...@@ -670,7 +649,8 @@ static int vmballoon_unlock_batched_page(struct vmballoon *b,
bool hv_success; bool hv_success;
u16 size_per_page = vmballoon_page_size(is_2m_pages); u16 size_per_page = vmballoon_page_size(is_2m_pages);
hv_success = vmballoon_send_batched_unlock(b, num_pages, is_2m_pages); hv_success = vmballoon_send_batched_lock(b, num_pages, is_2m_pages,
false);
if (!hv_success) if (!hv_success)
ret = -EIO; ret = -EIO;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment