virtio_balloon: fix handling of PAGE_SIZE != 4k
authorMichael S. Tsirkin <mst@redhat.com>
Thu, 12 Apr 2012 13:38:00 +0000 (16:38 +0300)
committerVarun Wadekar <vwadekar@nvidia.com>
Wed, 25 Apr 2012 06:14:02 +0000 (11:14 +0530)
commitd362ada9ee64cb5ea6c4cd59ceca63d3da7ab3f1
tree609b9023632de54a572b5b2032dd604bd5e38da7
parentd1b28b1d6f9e7cc48e4ce1cc570edda2b87ccec5
virtio_balloon: fix handling of PAGE_SIZE != 4k

As reported by David Gibson, current code handles PAGE_SIZE != 4k
completely wrong which can lead to guest memory corruption errors:

- page_to_balloon_pfn is wrong: e.g. on system with 64K page size
 it gives the same pfn value for 16 different pages.

- we also need to convert back to linux pfns when we free.

- for each linux page we need to tell host about multiple balloon
  pages, but code only adds one pfn to the array.

This patch fixes all that, tested with a 64k ppc64 kernel.

Reported-by: David Gibson <david@gibson.dropbear.id.au>
Tested-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
drivers/virtio/virtio_balloon.c