block: add image info query function bdrv_query_image_info()
This patch adds function bdrv_query_image_info(), which will retrieve image info in qmp object format. The implementation is based on the code moved from qemu-img.c, but uses block layer function to get snapshot info. Signed-off-by: Wenchao Xia <xiawenc@linux.vnet.ibm.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
		
							parent
							
								
									fb0ed4539c
								
							
						
					
					
						commit
						43526ec8d1
					
				
							
								
								
									
										43
									
								
								block/qapi.c
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								block/qapi.c
									
									
									
									
									
								
							| @ -88,18 +88,29 @@ int bdrv_query_snapshot_info_list(BlockDriverState *bs, | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void bdrv_collect_image_info(BlockDriverState *bs, | /**
 | ||||||
|                              ImageInfo *info, |  * bdrv_query_image_info: | ||||||
|                              const char *filename) |  * @bs: block device to examine | ||||||
|  |  * @p_info: location to store image information | ||||||
|  |  * @errp: location to store error information | ||||||
|  |  * | ||||||
|  |  * @p_info will be set only on success. On error, store error in @errp. | ||||||
|  |  */ | ||||||
|  | void bdrv_query_image_info(BlockDriverState *bs, | ||||||
|  |                            ImageInfo **p_info, | ||||||
|  |                            Error **errp) | ||||||
| { | { | ||||||
|     uint64_t total_sectors; |     uint64_t total_sectors; | ||||||
|     char backing_filename[1024]; |     const char *backing_filename; | ||||||
|     char backing_filename2[1024]; |     char backing_filename2[1024]; | ||||||
|     BlockDriverInfo bdi; |     BlockDriverInfo bdi; | ||||||
|  |     int ret; | ||||||
|  |     Error *err = NULL; | ||||||
|  |     ImageInfo *info = g_new0(ImageInfo, 1); | ||||||
| 
 | 
 | ||||||
|     bdrv_get_geometry(bs, &total_sectors); |     bdrv_get_geometry(bs, &total_sectors); | ||||||
| 
 | 
 | ||||||
|     info->filename        = g_strdup(filename); |     info->filename        = g_strdup(bs->filename); | ||||||
|     info->format          = g_strdup(bdrv_get_format_name(bs)); |     info->format          = g_strdup(bdrv_get_format_name(bs)); | ||||||
|     info->virtual_size    = total_sectors * 512; |     info->virtual_size    = total_sectors * 512; | ||||||
|     info->actual_size     = bdrv_get_allocated_file_size(bs); |     info->actual_size     = bdrv_get_allocated_file_size(bs); | ||||||
| @ -116,7 +127,7 @@ void bdrv_collect_image_info(BlockDriverState *bs, | |||||||
|         info->dirty_flag = bdi.is_dirty; |         info->dirty_flag = bdi.is_dirty; | ||||||
|         info->has_dirty_flag = true; |         info->has_dirty_flag = true; | ||||||
|     } |     } | ||||||
|     bdrv_get_backing_filename(bs, backing_filename, sizeof(backing_filename)); |     backing_filename = bs->backing_file; | ||||||
|     if (backing_filename[0] != '\0') { |     if (backing_filename[0] != '\0') { | ||||||
|         info->backing_filename = g_strdup(backing_filename); |         info->backing_filename = g_strdup(backing_filename); | ||||||
|         info->has_backing_filename = true; |         info->has_backing_filename = true; | ||||||
| @ -134,6 +145,26 @@ void bdrv_collect_image_info(BlockDriverState *bs, | |||||||
|             info->has_backing_filename_format = true; |             info->has_backing_filename_format = true; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     ret = bdrv_query_snapshot_info_list(bs, &info->snapshots, &err); | ||||||
|  |     switch (ret) { | ||||||
|  |     case 0: | ||||||
|  |         if (info->snapshots) { | ||||||
|  |             info->has_snapshots = true; | ||||||
|  |         } | ||||||
|  |         break; | ||||||
|  |     /* recoverable error */ | ||||||
|  |     case -ENOMEDIUM: | ||||||
|  |     case -ENOTSUP: | ||||||
|  |         error_free(err); | ||||||
|  |         break; | ||||||
|  |     default: | ||||||
|  |         error_propagate(errp, err); | ||||||
|  |         qapi_free_ImageInfo(info); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     *p_info = info; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| BlockInfo *bdrv_query_info(BlockDriverState *bs) | BlockInfo *bdrv_query_info(BlockDriverState *bs) | ||||||
|  | |||||||
| @ -32,9 +32,9 @@ | |||||||
| int bdrv_query_snapshot_info_list(BlockDriverState *bs, | int bdrv_query_snapshot_info_list(BlockDriverState *bs, | ||||||
|                                   SnapshotInfoList **p_list, |                                   SnapshotInfoList **p_list, | ||||||
|                                   Error **errp); |                                   Error **errp); | ||||||
| void bdrv_collect_image_info(BlockDriverState *bs, | void bdrv_query_image_info(BlockDriverState *bs, | ||||||
|                              ImageInfo *info, |                            ImageInfo **p_info, | ||||||
|                              const char *filename); |                            Error **errp); | ||||||
| BlockInfo *bdrv_query_info(BlockDriverState *s); | BlockInfo *bdrv_query_info(BlockDriverState *s); | ||||||
| BlockStats *bdrv_query_stats(const BlockDriverState *bs); | BlockStats *bdrv_query_stats(const BlockDriverState *bs); | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										11
									
								
								qemu-img.c
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								qemu-img.c
									
									
									
									
									
								
							| @ -1644,6 +1644,7 @@ static ImageInfoList *collect_image_info_list(const char *filename, | |||||||
|     ImageInfoList *head = NULL; |     ImageInfoList *head = NULL; | ||||||
|     ImageInfoList **last = &head; |     ImageInfoList **last = &head; | ||||||
|     GHashTable *filenames; |     GHashTable *filenames; | ||||||
|  |     Error *err = NULL; | ||||||
| 
 | 
 | ||||||
|     filenames = g_hash_table_new_full(g_str_hash, str_equal_func, NULL, NULL); |     filenames = g_hash_table_new_full(g_str_hash, str_equal_func, NULL, NULL); | ||||||
| 
 | 
 | ||||||
| @ -1665,11 +1666,11 @@ static ImageInfoList *collect_image_info_list(const char *filename, | |||||||
|             goto err; |             goto err; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         info = g_new0(ImageInfo, 1); |         bdrv_query_image_info(bs, &info, &err); | ||||||
|         bdrv_collect_image_info(bs, info, filename); |         if (error_is_set(&err)) { | ||||||
|         bdrv_query_snapshot_info_list(bs, &info->snapshots, NULL); |             error_report("%s", error_get_pretty(err)); | ||||||
|         if (info->snapshots) { |             error_free(err); | ||||||
|             info->has_snapshots = true; |             goto err; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         elem = g_new0(ImageInfoList, 1); |         elem = g_new0(ImageInfoList, 1); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Wenchao Xia
						Wenchao Xia