The host expects that the pressure report includes the pressure due to the
pages that have been ballooned. Make necessary adjustments to reflect that.
Also, include the free memory information in the pressure report.
Signed-off-by: K. Y. Srinivasan <kys@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
static void post_status(struct hv_dynmem_device *dm)
{
struct dm_status status;
static void post_status(struct hv_dynmem_device *dm)
{
struct dm_status status;
memset(&status, 0, sizeof(struct dm_status));
status.hdr.type = DM_STATUS_REPORT;
status.hdr.size = sizeof(struct dm_status);
status.hdr.trans_id = atomic_inc_return(&trans_id);
memset(&status, 0, sizeof(struct dm_status));
status.hdr.type = DM_STATUS_REPORT;
status.hdr.size = sizeof(struct dm_status);
status.hdr.trans_id = atomic_inc_return(&trans_id);
-
- status.num_committed = vm_memory_committed();
+ /*
+ * The host expects the guest to report free memory.
+ * Further, the host expects the pressure information to
+ * include the ballooned out pages.
+ */
+ status.num_avail = val.freeram;
+ status.num_committed = vm_memory_committed() + dm->num_pages_ballooned;
vmbus_sendpacket(dm->dev->channel, &status,
sizeof(struct dm_status),
vmbus_sendpacket(dm->dev->channel, &status,
sizeof(struct dm_status),