diff options
Diffstat (limited to 'drivers/virtio/virtio_balloon.c')
| -rw-r--r-- | drivers/virtio/virtio_balloon.c | 30 | 
1 files changed, 16 insertions, 14 deletions
diff --git a/drivers/virtio/virtio_balloon.c b/drivers/virtio/virtio_balloon.c index 1f572c00a1b..25ebe8eecdb 100644 --- a/drivers/virtio/virtio_balloon.c +++ b/drivers/virtio/virtio_balloon.c @@ -108,8 +108,7 @@ static void tell_host(struct virtio_balloon *vb, struct virtqueue *vq)  	sg_init_one(&sg, vb->pfns, sizeof(vb->pfns[0]) * vb->num_pfns);  	/* We should always be able to add one buffer to an empty queue. */ -	if (virtqueue_add_outbuf(vq, &sg, 1, vb, GFP_KERNEL) < 0) -		BUG(); +	virtqueue_add_outbuf(vq, &sg, 1, vb, GFP_KERNEL);  	virtqueue_kick(vq);  	/* When host has read buffer, this completes via balloon_ack */ @@ -258,8 +257,7 @@ static void stats_handle_request(struct virtio_balloon *vb)  	if (!virtqueue_get_buf(vq, &len))  		return;  	sg_init_one(&sg, vb->stats, sizeof(vb->stats)); -	if (virtqueue_add_outbuf(vq, &sg, 1, vb, GFP_KERNEL) < 0) -		BUG(); +	virtqueue_add_outbuf(vq, &sg, 1, vb, GFP_KERNEL);  	virtqueue_kick(vq);  } @@ -275,9 +273,8 @@ static inline s64 towards_target(struct virtio_balloon *vb)  	__le32 v;  	s64 target; -	vb->vdev->config->get(vb->vdev, -			      offsetof(struct virtio_balloon_config, num_pages), -			      &v, sizeof(v)); +	virtio_cread(vb->vdev, struct virtio_balloon_config, num_pages, &v); +  	target = le32_to_cpu(v);  	return target - vb->num_pages;  } @@ -286,9 +283,8 @@ static void update_balloon_size(struct virtio_balloon *vb)  {  	__le32 actual = cpu_to_le32(vb->num_pages); -	vb->vdev->config->set(vb->vdev, -			      offsetof(struct virtio_balloon_config, actual), -			      &actual, sizeof(actual)); +	virtio_cwrite(vb->vdev, struct virtio_balloon_config, actual, +		      &actual);  }  static int balloon(void *_vballoon) @@ -312,6 +308,12 @@ static int balloon(void *_vballoon)  		else if (diff < 0)  			leak_balloon(vb, -diff);  		update_balloon_size(vb); + +		/* +		 * For large balloon changes, we could spend a lot of time +		 * and always have work to do.  Be nice if preempt disabled. +		 */ +		cond_resched();  	}  	return 0;  } @@ -340,7 +342,7 @@ static int init_vqs(struct virtio_balloon *vb)  		/*  		 * Prime this virtqueue with one buffer so the hypervisor can -		 * use it to signal us later. +		 * use it to signal us later (it can't be broken yet!).  		 */  		sg_init_one(&sg, vb->stats, sizeof vb->stats);  		if (virtqueue_add_outbuf(vb->stats_vq, &sg, 1, vb, GFP_KERNEL) @@ -371,7 +373,7 @@ static const struct address_space_operations virtio_balloon_aops;   * This function preforms the balloon page migration task.   * Called through balloon_mapping->a_ops->migratepage   */ -int virtballoon_migratepage(struct address_space *mapping, +static int virtballoon_migratepage(struct address_space *mapping,  		struct page *newpage, struct page *page, enum migrate_mode mode)  {  	struct balloon_dev_info *vb_dev_info = balloon_page_device(page); @@ -513,7 +515,7 @@ static void virtballoon_remove(struct virtio_device *vdev)  	kfree(vb);  } -#ifdef CONFIG_PM +#ifdef CONFIG_PM_SLEEP  static int virtballoon_freeze(struct virtio_device *vdev)  {  	struct virtio_balloon *vb = vdev->priv; @@ -556,7 +558,7 @@ static struct virtio_driver virtio_balloon_driver = {  	.probe =	virtballoon_probe,  	.remove =	virtballoon_remove,  	.config_changed = virtballoon_changed, -#ifdef CONFIG_PM +#ifdef CONFIG_PM_SLEEP  	.freeze	=	virtballoon_freeze,  	.restore =	virtballoon_restore,  #endif  | 
