diff options
| author | Bob Liu <bob.liu@oracle.com> | 2015-04-03 14:42:59 +0800 | 
|---|---|---|
| committer | David Vrabel <david.vrabel@citrix.com> | 2015-04-27 11:41:12 +0100 | 
| commit | b44166cd46e28dd608d5baa5873047a40f32919c (patch) | |
| tree | 799b236c472067869782b2cf937d9d0d87852fc4 /drivers/xen | |
| parent | 325d73bf8fea8af2227240b7305253fb052d3a68 (diff) | |
xen/grant: introduce func gnttab_unmap_refs_sync()
There are several place using gnttab async unmap and wait for
completion, so move the common code to a function
gnttab_unmap_refs_sync().
Signed-off-by: Bob Liu <bob.liu@oracle.com>
Acked-by: Roger Pau Monné <roger.pau@citrix.com>
Acked-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
Diffstat (limited to 'drivers/xen')
| -rw-r--r-- | drivers/xen/gntdev.c | 28 | ||||
| -rw-r--r-- | drivers/xen/grant-table.c | 28 | 
2 files changed, 31 insertions, 25 deletions
| diff --git a/drivers/xen/gntdev.c b/drivers/xen/gntdev.c index d5bb1a33d0a3..89274850741b 100644 --- a/drivers/xen/gntdev.c +++ b/drivers/xen/gntdev.c @@ -327,30 +327,10 @@ static int map_grant_pages(struct grant_map *map)  	return err;  } -struct unmap_grant_pages_callback_data -{ -	struct completion completion; -	int result; -}; - -static void unmap_grant_callback(int result, -				 struct gntab_unmap_queue_data *data) -{ -	struct unmap_grant_pages_callback_data* d = data->data; - -	d->result = result; -	complete(&d->completion); -} -  static int __unmap_grant_pages(struct grant_map *map, int offset, int pages)  {  	int i, err = 0;  	struct gntab_unmap_queue_data unmap_data; -	struct unmap_grant_pages_callback_data data; - -	init_completion(&data.completion); -	unmap_data.data = &data; -	unmap_data.done= &unmap_grant_callback;  	if (map->notify.flags & UNMAP_NOTIFY_CLEAR_BYTE) {  		int pgno = (map->notify.addr >> PAGE_SHIFT); @@ -367,11 +347,9 @@ static int __unmap_grant_pages(struct grant_map *map, int offset, int pages)  	unmap_data.pages = map->pages + offset;  	unmap_data.count = pages; -	gnttab_unmap_refs_async(&unmap_data); - -	wait_for_completion(&data.completion); -	if (data.result) -		return data.result; +	err = gnttab_unmap_refs_sync(&unmap_data); +	if (err) +		return err;  	for (i = 0; i < pages; i++) {  		if (map->unmap_ops[offset+i].status) diff --git a/drivers/xen/grant-table.c b/drivers/xen/grant-table.c index 17972fbacddc..b1c7170e5c9e 100644 --- a/drivers/xen/grant-table.c +++ b/drivers/xen/grant-table.c @@ -123,6 +123,11 @@ struct gnttab_ops {  	int (*query_foreign_access)(grant_ref_t ref);  }; +struct unmap_refs_callback_data { +	struct completion completion; +	int result; +}; +  static struct gnttab_ops *gnttab_interface;  static int grant_table_version; @@ -863,6 +868,29 @@ void gnttab_unmap_refs_async(struct gntab_unmap_queue_data* item)  }  EXPORT_SYMBOL_GPL(gnttab_unmap_refs_async); +static void unmap_refs_callback(int result, +		struct gntab_unmap_queue_data *data) +{ +	struct unmap_refs_callback_data *d = data->data; + +	d->result = result; +	complete(&d->completion); +} + +int gnttab_unmap_refs_sync(struct gntab_unmap_queue_data *item) +{ +	struct unmap_refs_callback_data data; + +	init_completion(&data.completion); +	item->data = &data; +	item->done = &unmap_refs_callback; +	gnttab_unmap_refs_async(item); +	wait_for_completion(&data.completion); + +	return data.result; +} +EXPORT_SYMBOL_GPL(gnttab_unmap_refs_sync); +  static int gnttab_map_frames_v1(xen_pfn_t *frames, unsigned int nr_gframes)  {  	int rc; | 
