X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=blockdev.h;h=3587786a648fd8f926bb7fcdbf3b1c9788601d1e;hb=69ed8366b1e8602b6b7555902f453d3e5df5dd41;hp=653affcc9b181b7723f7586995d09997bd18e215;hpb=4447d609688e75a40a10b559e3b6ae83843e3095;p=qemu.git diff --git a/blockdev.h b/blockdev.h index 653affcc9..3587786a6 100644 --- a/blockdev.h +++ b/blockdev.h @@ -18,6 +18,13 @@ void blockdev_auto_del(BlockDriverState *bs); #define BLOCK_SERIAL_STRLEN 20 +typedef enum { + IF_DEFAULT = -1, /* for use with drive_add() only */ + IF_NONE, + IF_IDE, IF_SCSI, IF_FLOPPY, IF_PFLASH, IF_MTD, IF_SD, IF_VIRTIO, IF_XEN, + IF_COUNT +} BlockInterfaceType; + struct DriveInfo { BlockDriverState *bdrv; char *id; @@ -26,21 +33,25 @@ struct DriveInfo { int bus; int unit; int auto_del; /* see blockdev_mark_auto_del() */ + int media_cd; QemuOpts *opts; char serial[BLOCK_SERIAL_STRLEN + 1]; QTAILQ_ENTRY(DriveInfo) next; + int refcount; }; -#define MAX_IDE_DEVS 2 -#define MAX_SCSI_DEVS 7 - DriveInfo *drive_get(BlockInterfaceType type, int bus, int unit); +DriveInfo *drive_get_by_index(BlockInterfaceType type, int index); int drive_get_max_bus(BlockInterfaceType type); -void drive_uninit(DriveInfo *dinfo); +DriveInfo *drive_get_next(BlockInterfaceType type); +void drive_get_ref(DriveInfo *dinfo); +void drive_put_ref(DriveInfo *dinfo); DriveInfo *drive_get_by_blockdev(BlockDriverState *bs); -QemuOpts *drive_add(const char *file, const char *fmt, ...) GCC_FMT_ATTR(2, 3); -DriveInfo *drive_init(QemuOpts *arg, int default_to_scsi, int *fatal_error); +QemuOpts *drive_def(const char *optstr); +QemuOpts *drive_add(BlockInterfaceType type, int index, const char *file, + const char *optstr); +DriveInfo *drive_init(QemuOpts *arg, int default_to_scsi); /* device-hotplug */ @@ -51,5 +62,8 @@ 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); +int do_drive_del(Monitor *mon, const QDict *qdict, QObject **ret_data); +int do_snapshot_blkdev(Monitor *mon, const QDict *qdict, QObject **ret_data); +int do_block_resize(Monitor *mon, const QDict *qdict, QObject **ret_data); #endif