|
@@ -1,6 +1,5 @@
|
|
#include "xen_backend.h"
|
|
#include "xen_backend.h"
|
|
#include "blockdev.h"
|
|
#include "blockdev.h"
|
|
-#include "block_int.h" /* XXX */
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------- */
|
|
/* ------------------------------------------------------------- */
|
|
|
|
|
|
@@ -99,10 +98,11 @@ int xen_config_dev_blk(DriveInfo *disk)
|
|
int cdrom = disk->media_cd;
|
|
int cdrom = disk->media_cd;
|
|
const char *devtype = cdrom ? "cdrom" : "disk";
|
|
const char *devtype = cdrom ? "cdrom" : "disk";
|
|
const char *mode = cdrom ? "r" : "w";
|
|
const char *mode = cdrom ? "r" : "w";
|
|
|
|
+ const char *filename = qemu_opt_get(disk->opts, "file");
|
|
|
|
|
|
snprintf(device_name, sizeof(device_name), "xvd%c", 'a' + disk->unit);
|
|
snprintf(device_name, sizeof(device_name), "xvd%c", 'a' + disk->unit);
|
|
xen_be_printf(NULL, 1, "config disk %d [%s]: %s\n",
|
|
xen_be_printf(NULL, 1, "config disk %d [%s]: %s\n",
|
|
- disk->unit, device_name, disk->bdrv->filename);
|
|
|
|
|
|
+ disk->unit, device_name, filename);
|
|
xen_config_dev_dirs("vbd", "qdisk", vdev, fe, be, sizeof(fe));
|
|
xen_config_dev_dirs("vbd", "qdisk", vdev, fe, be, sizeof(fe));
|
|
|
|
|
|
/* frontend */
|
|
/* frontend */
|
|
@@ -112,7 +112,7 @@ int xen_config_dev_blk(DriveInfo *disk)
|
|
/* backend */
|
|
/* backend */
|
|
xenstore_write_str(be, "dev", device_name);
|
|
xenstore_write_str(be, "dev", device_name);
|
|
xenstore_write_str(be, "type", "file");
|
|
xenstore_write_str(be, "type", "file");
|
|
- xenstore_write_str(be, "params", disk->bdrv->filename);
|
|
|
|
|
|
+ xenstore_write_str(be, "params", filename);
|
|
xenstore_write_str(be, "mode", mode);
|
|
xenstore_write_str(be, "mode", mode);
|
|
|
|
|
|
/* common stuff */
|
|
/* common stuff */
|