blockdev-backup: Don't move target AioContext if it's attached
If the BDS is attached, it will want to stay on the AioContext where its BlockBackend is. Don't call bdrv_set_aio_context in this case. Signed-off-by: Fam Zheng <famz@redhat.com> Message-id: 1463969978-24970-3-git-send-email-famz@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
		
				
					committed by
					
						 Stefan Hajnoczi
						Stefan Hajnoczi
					
				
			
			
				
	
			
			
			
						parent
						
							0d97891312
						
					
				
				
					commit
					efd7556708
				
			
							
								
								
									
										12
									
								
								blockdev.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								blockdev.c
									
									
									
									
									
								
							| @@ -3371,7 +3371,17 @@ void do_blockdev_backup(const char *device, const char *target, | ||||
|         goto out; | ||||
|     } | ||||
|  | ||||
|     bdrv_set_aio_context(target_bs, aio_context); | ||||
|     if (bdrv_get_aio_context(target_bs) != aio_context) { | ||||
|         if (!bdrv_has_blk(target_bs)) { | ||||
|             /* The target BDS is not attached, we can safely move it to another | ||||
|              * AioContext. */ | ||||
|             bdrv_set_aio_context(target_bs, aio_context); | ||||
|         } else { | ||||
|             error_setg(errp, "Target is attached to a different thread from " | ||||
|                              "source."); | ||||
|             goto out; | ||||
|         } | ||||
|     } | ||||
|     backup_start(bs, target_bs, speed, sync, NULL, on_source_error, | ||||
|                  on_target_error, block_job_cb, bs, txn, &local_err); | ||||
|     if (local_err != NULL) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user