mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-25 16:17:02 +00:00 
			
		
		
		
	 14bafc5407
			
		
	
	
		14bafc5407
		
	
	
	
	
		
			
			We automatically delete blockdev host parts on unplug of the guest device. Too much magic, but we can't change that now. The delete happens early in the guest device teardown, before the connection to the host part is severed. Thus, the guest part's pointer to the host part dangles for a brief time. No actual harm comes from this, but we'll catch such dangling pointers a few commits down the road. Clean up the dangling pointers by delaying the automatic deletion until the guest part's pointer is gone. Device usb-storage deliberately makes two qdev properties refer to the same drive, because it automatically creates a second device. Again, too much magic we can't change now. Multiple references worked okay before, but now free_drive() dies for the second one. Zap the extra reference. Signed-off-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * QEMU host block devices
 | |
|  *
 | |
|  * Copyright (c) 2003-2008 Fabrice Bellard
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2 or
 | |
|  * later.  See the COPYING file in the top-level directory.
 | |
|  */
 | |
| 
 | |
| #ifndef BLOCKDEV_H
 | |
| #define BLOCKDEV_H
 | |
| 
 | |
| #include "block.h"
 | |
| #include "qemu-queue.h"
 | |
| 
 | |
| void blockdev_mark_auto_del(BlockDriverState *bs);
 | |
| void blockdev_auto_del(BlockDriverState *bs);
 | |
| 
 | |
| typedef enum {
 | |
|     IF_NONE,
 | |
|     IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN,
 | |
|     IF_COUNT
 | |
| } BlockInterfaceType;
 | |
| 
 | |
| #define BLOCK_SERIAL_STRLEN 20
 | |
| 
 | |
| typedef struct DriveInfo {
 | |
|     BlockDriverState *bdrv;
 | |
|     char *id;
 | |
|     const char *devaddr;
 | |
|     BlockInterfaceType type;
 | |
|     int bus;
 | |
|     int unit;
 | |
|     int auto_del;               /* see blockdev_mark_auto_del() */
 | |
|     QemuOpts *opts;
 | |
|     char serial[BLOCK_SERIAL_STRLEN + 1];
 | |
|     QTAILQ_ENTRY(DriveInfo) next;
 | |
| } DriveInfo;
 | |
| 
 | |
| #define MAX_IDE_DEVS	2
 | |
| #define MAX_SCSI_DEVS	7
 | |
| 
 | |
| extern DriveInfo *drive_get(BlockInterfaceType type, int bus, int unit);
 | |
| extern DriveInfo *drive_get_by_id(const char *id);
 | |
| extern int drive_get_max_bus(BlockInterfaceType type);
 | |
| extern void drive_uninit(DriveInfo *dinfo);
 | |
| extern DriveInfo *drive_get_by_blockdev(BlockDriverState *bs);
 | |
| 
 | |
| extern QemuOpts *drive_add(const char *file, const char *fmt, ...);
 | |
| extern DriveInfo *drive_init(QemuOpts *arg, int default_to_scsi,
 | |
|                              int *fatal_error);
 | |
| 
 | |
| /* device-hotplug */
 | |
| 
 | |
| DriveInfo *add_init_drive(const char *opts);
 | |
| 
 | |
| void do_commit(Monitor *mon, const QDict *qdict);
 | |
| int do_eject(Monitor *mon, const QDict *qdict, QObject **ret_data);
 | |
| int do_block_set_passwd(Monitor *mon, const QDict *qdict, QObject **ret_data);
 | |
| int do_change_block(Monitor *mon, const char *device,
 | |
|                     const char *filename, const char *fmt);
 | |
| 
 | |
| #endif
 |