|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH V11.1 1/3] libxl: Add support for Virtio disk configuration
On 20.07.22 06:29, Jiamei Xie wrote:
> Hi Oleksandr,
Hello Jiamei
>
> We have tested it on arm64 with " disk = [ 'phy:/usr/share/guests/disk.img0,
> xvda1, backendtype=standalone, specification=virtio']". It works ok.
>
> Tested-by: Jiamei Xie <jiamei.xie@xxxxxxx>
> Tested-by: Henry Wang <Henry.Wang@xxxxxxx>
Thank you for the testing!
>
> Best wishes
> Jiamei Xie
>
>
>> -----Original Message-----
>> From: Xen-devel <xen-devel-bounces@xxxxxxxxxxxxxxxxxxxx> On Behalf Of
>> Oleksandr Tyshchenko
>> Sent: Sunday, July 17, 2022 12:38 AM
>> To: xen-devel@xxxxxxxxxxxxxxxxxxxx
>> Cc: Oleksandr Tyshchenko <oleksandr_tyshchenko@xxxxxxxx>; Wei Liu
>> <wl@xxxxxxx>; Anthony PERARD <anthony.perard@xxxxxxxxxx>; George
>> Dunlap <george.dunlap@xxxxxxxxxx>; Nick Rosbrook
>> <rosbrookn@xxxxxxxxx>; Juergen Gross <jgross@xxxxxxxx>; Stefano
>> Stabellini <sstabellini@xxxxxxxxxx>; Julien Grall <julien@xxxxxxx>; Volodymyr
>> Babchuk <Volodymyr_Babchuk@xxxxxxxx>; Bertrand Marquis
>> <Bertrand.Marquis@xxxxxxx>
>> Subject: [PATCH V11.1 1/3] libxl: Add support for Virtio disk configuration
>>
>> From: Oleksandr Tyshchenko <oleksandr_tyshchenko@xxxxxxxx>
>>
>> This patch adds basic support for configuring and assisting virtio-mmio
>> based virtio-disk backend (emulator) which is intended to run out of
>> Qemu and could be run in any domain.
>> Although the Virtio block device is quite different from traditional
>> Xen PV block device (vbd) from the toolstack's point of view:
>> - as the frontend is virtio-blk which is not a Xenbus driver, nothing
>> written to Xenstore are fetched by the frontend currently ("vdev"
>> is not passed to the frontend). But this might need to be revised
>> in future, so frontend data might be written to Xenstore in order to
>> support hotplugging virtio devices or passing the backend domain id
>> on arch where the device-tree is not available.
>> - the ring-ref/event-channel are not used for the backend<->frontend
>> communication, the proposed IPC for Virtio is IOREQ/DM
>> it is still a "block device" and ought to be integrated in existing
>> "disk" handling. So, re-use (and adapt) "disk" parsing/configuration
>> logic to deal with Virtio devices as well.
>>
>> For the immediate purpose and an ability to extend that support for
>> other use-cases in future (Qemu, virtio-pci, etc) perform the following
>> actions:
>> - Add new disk backend type (LIBXL_DISK_BACKEND_STANDALONE) and
>> reflect
>> that in the configuration
>> - Introduce new disk "specification" and "transport" fields to struct
>> libxl_device_disk. Both are written to the Xenstore. The transport
>> field is only used for the specification "virtio" and it assumes
>> only "mmio" value for now.
>> - Introduce new "specification" option with "xen" communication
>> protocol being default value.
>> - Add new device kind (LIBXL__DEVICE_KIND_VIRTIO_DISK) as current
>> one (LIBXL__DEVICE_KIND_VBD) doesn't fit into Virtio disk model
>>
>> An example of domain configuration for Virtio disk:
>> disk = [ 'phy:/dev/mmcblk0p3, xvda1, backendtype=standalone,
>> specification=virtio']
>>
>> Nothing has changed for default Xen disk configuration.
>>
>> Please note, this patch is not enough for virtio-disk to work
>> on Xen (Arm), as for every Virtio device (including disk) we need
>> to allocate Virtio MMIO params (IRQ and memory region) and pass
>> them to the backend, also update Guest device-tree. The subsequent
>> patch will add these missing bits. For the current patch,
>> the default "irq" and "base" are just written to the Xenstore.
>> This is not an ideal splitting, but this way we avoid breaking
>> the bisectability.
>>
>> Signed-off-by: Oleksandr Tyshchenko <oleksandr_tyshchenko@xxxxxxxx>
>> ---
>> Changes RFC -> V1:
>> - no changes
>>
>> Changes V1 -> V2:
>> - rebase according to the new location of libxl_virtio_disk.c
>>
>> Changes V2 -> V3:
>> - no changes
>>
>> Changes V3 -> V4:
>> - rebase according to the new argument for DEFINE_DEVICE_TYPE_STRUCT
>>
>> Changes V4 -> V5:
>> - split the changes, change the order of the patches
>> - update patch description
>> - don't introduce new "vdisk" configuration option with own parsing
>> logic,
>> re-use Xen PV block "disk" parsing/configuration logic for the
>> virtio-disk
>> - introduce "virtio" flag and document it's usage
>> - add LIBXL_HAVE_DEVICE_DISK_VIRTIO
>> - update libxlu_disk_l.[ch]
>> - drop num_disks variable/MAX_VIRTIO_DISKS
>> - drop Wei's T-b
>>
>> Changes V5 -> V6:
>> - rebase on current staging
>> - use "%"PRIu64 instead of %lu for disk->base in device_disk_add()
>> - update *.gen.go files
>>
>> Changes V6 -> V7:
>> - rebase on current staging
>> - update *.gen.go files and libxlu_disk_l.[ch] files
>> - update patch description
>> - rework significantly to support more flexible configuration
>> and have more generic basic implementation for being able to extend
>> that for other use-cases (virtio-pci, qemu, etc).
>>
>> Changes V7 -> V8:
>> - update *.gen.go files and libxlu_disk_l.[ch] files
>> - update patch description and comments in the code
>> - use "specification" config option instead of "protocol"
>> - update libxl_types.idl and code according to new fields
>> in libxl_device_disk
>>
>> Changes V8 -> V9:
>> - update (and harden) checks in libxl__device_disk_setdefault(),
>> return error in case of incorrect settings of specification
>> and transport
>> - remove both asserts in device_disk_add()
>> - update virtio related code in libxl__disk_from_xenstore(),
>> do not fail if specification node is absent, replace
>> open-coded checks of fetched specification and transport by
>> libxl_disk_specification_from_string() and
>> libxl_disk_transport_from_string()
>> respectively
>> - s/libxl_device_disk_get_path/libxl__device_disk_get_path
>> - add a comment for virtio-mmio parameters in struct libxl_device_disk
>>
>> Changes V9 -> V10:
>> - s/ERROR_FAIL/ERROR_INVAL in both places in
>> libxl__device_disk_setdefault()
>> - rework libxl__device_disk_get_path()
>>
>> Changes V10 -> V10.1:
>> - fix small coding style issue in libxl__device_disk_get_path()
>> - drop specification check in main_blockattach() and add
>> required check in libxl__device_disk_setdefault()
>> - update specification check in main_blockdetach()
>>
>> Changes V10.1 -> V11:
>> - Anthony already gave his Reviewed-by, I dropped it due to the changes
>> - George already gave his Acked-by, I dropped it due to the changes
>> - s/other/standalone for the backendtype
>>
>> Changes V11 -> V11.1:
>> - rebase
>> ---
>> docs/man/xl-disk-configuration.5.pod.in | 38 +-
>> tools/golang/xenlight/helpers.gen.go | 8 +
>> tools/golang/xenlight/types.gen.go | 18 +
>> tools/include/libxl.h | 7 +
>> tools/libs/light/libxl_device.c | 62 +-
>> tools/libs/light/libxl_disk.c | 146 +++-
>> tools/libs/light/libxl_internal.h | 2 +
>> tools/libs/light/libxl_types.idl | 18 +
>> tools/libs/light/libxl_types_internal.idl | 1 +
>> tools/libs/light/libxl_utils.c | 2 +
>> tools/libs/util/libxlu_disk_l.c | 959 +++++++++++-----------
>> tools/libs/util/libxlu_disk_l.h | 2 +-
>> tools/libs/util/libxlu_disk_l.l | 9 +
>> tools/xl/xl_block.c | 6 +
>> 14 files changed, 798 insertions(+), 480 deletions(-)
>>
>> diff --git a/docs/man/xl-disk-configuration.5.pod.in b/docs/man/xl-disk-
>> configuration.5.pod.in
>> index 95d039655a..bc945cc517 100644
>> --- a/docs/man/xl-disk-configuration.5.pod.in
>> +++ b/docs/man/xl-disk-configuration.5.pod.in
>> @@ -232,7 +232,7 @@ Specifies the backend implementation to use
>>
>> =item Supported values
>>
>> -phy, qdisk
>> +phy, qdisk, standalone
>>
>> =item Mandatory
>>
>> @@ -244,11 +244,13 @@ Automatically determine which backend to use.
>>
>> =back
>>
>> -This does not affect the guest's view of the device. It controls
>> -which software implementation of the Xen backend driver is used.
>> +It controls which software implementation of the backend driver is used.
>> +Depending on the "specification" option this may affect the guest's view
>> +of the device.
>>
>> Not all backend drivers support all combinations of other options.
>> -For example, "phy" does not support formats other than "raw".
>> +For example, "phy" and "standalone" do not support formats other than
>> "raw"
>> +and "standalone" does not support specifications other than "virtio".
>> Normally this option should not be specified, in which case libxl will
>> automatically determine the most suitable backend.
>>
>> @@ -373,8 +375,36 @@ processing or causing malfunction to the frontend
>> or the whole domain.
>>
>> Note frontends can ignore such recommendation.
>>
>> +=item B<specification>=I<SPECIFICATION>
>> +
>> +=over 4
>> +
>> +=item Description
>> +
>> +Specifies the communication protocol (specification) to use for the chosen
>> +"backendtype" option
>> +
>> +=item Supported values
>> +
>> +xen, virtio
>> +
>> +=item Mandatory
>> +
>> +No
>> +
>> +=item Default value
>> +
>> +xen
>> +
>> =back
>>
>> +Besides forcing toolstack to use specific backend implementation, this also
>> +affects the guest's view of the device. For example, "virtio" requires
>> +Virtio frontend driver (virtio-blk) to be used. Please note, the virtual
>> +device (vdev) is not passed to the guest in that case, but it still must be
>> +specified for the internal purposes.
>> +
>> +=back
>>
>> =head1 COLO Parameters
>>
>> diff --git a/tools/golang/xenlight/helpers.gen.go
>> b/tools/golang/xenlight/helpers.gen.go
>> index dece545ee0..ad8c11eae1 100644
>> --- a/tools/golang/xenlight/helpers.gen.go
>> +++ b/tools/golang/xenlight/helpers.gen.go
>> @@ -1763,6 +1763,10 @@ x.DirectIoSafe = bool(xc.direct_io_safe)
>> if err := x.DiscardEnable.fromC(&xc.discard_enable);err != nil {
>> return fmt.Errorf("converting field DiscardEnable: %v", err)
>> }
>> +x.Specification = DiskSpecification(xc.specification)
>> +x.Transport = DiskTransport(xc.transport)
>> +x.Irq = uint32(xc.irq)
>> +x.Base = uint64(xc.base)
>> if err := x.ColoEnable.fromC(&xc.colo_enable);err != nil {
>> return fmt.Errorf("converting field ColoEnable: %v", err)
>> }
>> @@ -1800,6 +1804,10 @@ xc.direct_io_safe = C.bool(x.DirectIoSafe)
>> if err := x.DiscardEnable.toC(&xc.discard_enable); err != nil {
>> return fmt.Errorf("converting field DiscardEnable: %v", err)
>> }
>> +xc.specification = C.libxl_disk_specification(x.Specification)
>> +xc.transport = C.libxl_disk_transport(x.Transport)
>> +xc.irq = C.uint32_t(x.Irq)
>> +xc.base = C.uint64_t(x.Base)
>> if err := x.ColoEnable.toC(&xc.colo_enable); err != nil {
>> return fmt.Errorf("converting field ColoEnable: %v", err)
>> }
>> diff --git a/tools/golang/xenlight/types.gen.go
>> b/tools/golang/xenlight/types.gen.go
>> index 253c9ad93d..b9143390f8 100644
>> --- a/tools/golang/xenlight/types.gen.go
>> +++ b/tools/golang/xenlight/types.gen.go
>> @@ -99,6 +99,20 @@ DiskBackendUnknown DiskBackend = 0
>> DiskBackendPhy DiskBackend = 1
>> DiskBackendTap DiskBackend = 2
>> DiskBackendQdisk DiskBackend = 3
>> +DiskBackendStandalone DiskBackend = 4
>> +)
>> +
>> +type DiskSpecification int
>> +const(
>> +DiskSpecificationUnknown DiskSpecification = 0
>> +DiskSpecificationXen DiskSpecification = 1
>> +DiskSpecificationVirtio DiskSpecification = 2
>> +)
>> +
>> +type DiskTransport int
>> +const(
>> +DiskTransportUnknown DiskTransport = 0
>> +DiskTransportMmio DiskTransport = 1
>> )
>>
>> type NicType int
>> @@ -645,6 +659,10 @@ Readwrite int
>> IsCdrom int
>> DirectIoSafe bool
>> DiscardEnable Defbool
>> +Specification DiskSpecification
>> +Transport DiskTransport
>> +Irq uint32
>> +Base uint64
>> ColoEnable Defbool
>> ColoRestoreEnable Defbool
>> ColoHost string
>> diff --git a/tools/include/libxl.h b/tools/include/libxl.h
>> index f351669039..2321a648a5 100644
>> --- a/tools/include/libxl.h
>> +++ b/tools/include/libxl.h
>> @@ -549,6 +549,13 @@
>> */
>> #define LIBXL_HAVE_ASSISTED_APIC 1
>>
>> +/*
>> + * LIBXL_HAVE_DEVICE_DISK_SPECIFICATION indicates that 'specification'
>> and
>> + * 'transport' fields (of libxl_disk_specification and libxl_disk_transport
>> + * types respectively) are present in libxl_device_disk.
>> + */
>> +#define LIBXL_HAVE_DEVICE_DISK_SPECIFICATION 1
>> +
>> /*
>> * libxl ABI compatibility
>> *
>> diff --git a/tools/libs/light/libxl_device.c
>> b/tools/libs/light/libxl_device.c
>> index e6025d135e..a75c21d433 100644
>> --- a/tools/libs/light/libxl_device.c
>> +++ b/tools/libs/light/libxl_device.c
>> @@ -289,9 +289,16 @@ static int disk_try_backend(disk_try_backend_args
>> *a,
>> libxl_disk_backend backend)
>> {
>> libxl__gc *gc = a->gc;
>> + libxl_disk_specification specification = a->disk->specification;
>> /* returns 0 (ie, DISK_BACKEND_UNKNOWN) on failure, or
>> * backend on success */
>>
>> + if ((specification == LIBXL_DISK_SPECIFICATION_VIRTIO &&
>> + backend != LIBXL_DISK_BACKEND_STANDALONE) ||
>> + (specification != LIBXL_DISK_SPECIFICATION_VIRTIO &&
>> + backend == LIBXL_DISK_BACKEND_STANDALONE))
>> + goto bad_specification;
>> +
>> switch (backend) {
>> case LIBXL_DISK_BACKEND_PHY:
>> if (a->disk->format != LIBXL_DISK_FORMAT_RAW) {
>> @@ -329,6 +336,29 @@ static int disk_try_backend(disk_try_backend_args
>> *a,
>> if (a->disk->script) goto bad_script;
>> return backend;
>>
>> + case LIBXL_DISK_BACKEND_STANDALONE:
>> + if (a->disk->format != LIBXL_DISK_FORMAT_RAW)
>> + goto bad_format;
>> +
>> + if (a->disk->script)
>> + goto bad_script;
>> +
>> + if (libxl_defbool_val(a->disk->colo_enable))
>> + goto bad_colo;
>> +
>> + if (a->disk->backend_domid != LIBXL_TOOLSTACK_DOMID) {
>> + LOG(DEBUG, "Disk vdev=%s, is using a storage driver domain, "
>> + "skipping physical device check", a->disk->vdev);
>> + return backend;
>> + }
>> +
>> + if (libxl__try_phy_backend(a->stab.st_mode))
>> + return backend;
>> +
>> + LOG(DEBUG, "Disk vdev=%s, backend standalone unsuitable as phys
>> path not a "
>> + "block device", a->disk->vdev);
>> + return 0;
>> +
>> default:
>> LOG(DEBUG, "Disk vdev=%s, backend %d unknown", a->disk->vdev,
>> backend);
>> return 0;
>> @@ -352,6 +382,12 @@ static int disk_try_backend(disk_try_backend_args
>> *a,
>> LOG(DEBUG, "Disk vdev=%s, backend %s not compatible with colo",
>> a->disk->vdev, libxl_disk_backend_to_string(backend));
>> return 0;
>> +
>> + bad_specification:
>> + LOG(DEBUG, "Disk vdev=%s, backend %s not compatible with
>> specification %s",
>> + a->disk->vdev, libxl_disk_backend_to_string(backend),
>> + libxl_disk_specification_to_string(specification));
>> + return 0;
>> }
>>
>> int libxl__backendpath_parse_domid(libxl__gc *gc, const char *be_path,
>> @@ -376,8 +412,9 @@ int libxl__device_disk_set_backend(libxl__gc *gc,
>> libxl_device_disk *disk) {
>> a.gc = gc;
>> a.disk = disk;
>>
>> - LOG(DEBUG, "Disk vdev=%s spec.backend=%s", disk->vdev,
>> - libxl_disk_backend_to_string(disk->backend));
>> + LOG(DEBUG, "Disk vdev=%s spec.backend=%s specification=%s", disk-
>>> vdev,
>> + libxl_disk_backend_to_string(disk->backend),
>> + libxl_disk_specification_to_string(disk->specification));
>>
>> if (disk->format == LIBXL_DISK_FORMAT_EMPTY) {
>> if (!disk->is_cdrom) {
>> @@ -392,7 +429,8 @@ int libxl__device_disk_set_backend(libxl__gc *gc,
>> libxl_device_disk *disk) {
>> }
>> memset(&a.stab, 0, sizeof(a.stab));
>> } else if ((disk->backend == LIBXL_DISK_BACKEND_UNKNOWN ||
>> - disk->backend == LIBXL_DISK_BACKEND_PHY) &&
>> + disk->backend == LIBXL_DISK_BACKEND_PHY ||
>> + disk->backend == LIBXL_DISK_BACKEND_STANDALONE) &&
>> disk->backend_domid == LIBXL_TOOLSTACK_DOMID &&
>> !disk->script) {
>> if (stat(disk->pdev_path, &a.stab)) {
>> @@ -408,7 +446,8 @@ int libxl__device_disk_set_backend(libxl__gc *gc,
>> libxl_device_disk *disk) {
>> ok=
>> disk_try_backend(&a, LIBXL_DISK_BACKEND_PHY) ?:
>> disk_try_backend(&a, LIBXL_DISK_BACKEND_QDISK) ?:
>> - disk_try_backend(&a, LIBXL_DISK_BACKEND_TAP);
>> + disk_try_backend(&a, LIBXL_DISK_BACKEND_TAP) ?:
>> + disk_try_backend(&a, LIBXL_DISK_BACKEND_STANDALONE);
>> if (ok)
>> LOG(DEBUG, "Disk vdev=%s, using backend %s",
>> disk->vdev,
>> @@ -441,10 +480,25 @@ char
>> *libxl__device_disk_string_of_backend(libxl_disk_backend backend)
>> case LIBXL_DISK_BACKEND_QDISK: return "qdisk";
>> case LIBXL_DISK_BACKEND_TAP: return "phy";
>> case LIBXL_DISK_BACKEND_PHY: return "phy";
>> + case LIBXL_DISK_BACKEND_STANDALONE: return "standalone";
>> + default: return NULL;
>> + }
>> +}
>> +
>> +char *libxl__device_disk_string_of_specification(libxl_disk_specification
>> specification)
>> +{
>> + switch (specification) {
>> + case LIBXL_DISK_SPECIFICATION_XEN: return "xen";
>> + case LIBXL_DISK_SPECIFICATION_VIRTIO: return "virtio";
>> default: return NULL;
>> }
>> }
>>
>> +char *libxl__device_disk_string_of_transport(libxl_disk_transport transport)
>> +{
>> + return (transport == LIBXL_DISK_TRANSPORT_MMIO ? "mmio" : NULL);
>> +}
>> +
>> const char *libxl__qemu_disk_format_string(libxl_disk_format format)
>> {
>> switch (format) {
>> diff --git a/tools/libs/light/libxl_disk.c b/tools/libs/light/libxl_disk.c
>> index 9da2b2ed27..ea3623dd6f 100644
>> --- a/tools/libs/light/libxl_disk.c
>> +++ b/tools/libs/light/libxl_disk.c
>> @@ -164,6 +164,30 @@ static int libxl__device_disk_setdefault(libxl__gc *gc,
>> uint32_t domid,
>> rc = libxl__resolve_domid(gc, disk->backend_domname, &disk-
>>> backend_domid);
>> if (rc < 0) return rc;
>>
>> + if (disk->specification == LIBXL_DISK_SPECIFICATION_UNKNOWN)
>> + disk->specification = LIBXL_DISK_SPECIFICATION_XEN;
>> +
>> + if (disk->specification == LIBXL_DISK_SPECIFICATION_XEN &&
>> + disk->transport != LIBXL_DISK_TRANSPORT_UNKNOWN) {
>> + LOGD(ERROR, domid, "Transport is only supported for specification
>> virtio");
>> + return ERROR_INVAL;
>> + }
>> +
>> + /* Force transport mmio for specification virtio for now */
>> + if (disk->specification == LIBXL_DISK_SPECIFICATION_VIRTIO) {
>> + if (!(disk->transport == LIBXL_DISK_TRANSPORT_UNKNOWN ||
>> + disk->transport == LIBXL_DISK_TRANSPORT_MMIO)) {
>> + LOGD(ERROR, domid, "Unsupported transport for specification
>> virtio");
>> + return ERROR_INVAL;
>> + }
>> + disk->transport = LIBXL_DISK_TRANSPORT_MMIO;
>> + }
>> +
>> + if (hotplug && disk->specification == LIBXL_DISK_SPECIFICATION_VIRTIO) {
>> + LOGD(ERROR, domid, "Hotplug isn't supported for specification
>> virtio");
>> + return ERROR_FAIL;
>> + }
>> +
>> /* Force Qdisk backend for CDROM devices of guests with a device model.
>> */
>> if (disk->is_cdrom != 0 &&
>> libxl__domain_type(gc, domid) == LIBXL_DOMAIN_TYPE_HVM) {
>> @@ -205,6 +229,9 @@ static int libxl__device_from_disk(libxl__gc *gc,
>> uint32_t domid,
>> case LIBXL_DISK_BACKEND_QDISK:
>> device->backend_kind = LIBXL__DEVICE_KIND_QDISK;
>> break;
>> + case LIBXL_DISK_BACKEND_STANDALONE:
>> + device->backend_kind = LIBXL__DEVICE_KIND_VIRTIO_DISK;
>> + break;
>> default:
>> LOGD(ERROR, domid, "Unrecognized disk backend type: %d",
>> disk->backend);
>> @@ -213,7 +240,8 @@ static int libxl__device_from_disk(libxl__gc *gc,
>> uint32_t domid,
>>
>> device->domid = domid;
>> device->devid = devid;
>> - device->kind = LIBXL__DEVICE_KIND_VBD;
>> + device->kind = disk->backend == LIBXL_DISK_BACKEND_STANDALONE ?
>> + LIBXL__DEVICE_KIND_VIRTIO_DISK : LIBXL__DEVICE_KIND_VBD;
>>
>> return 0;
>> }
>> @@ -331,7 +359,14 @@ static void device_disk_add(libxl__egc *egc,
>> uint32_t domid,
>>
>> assert(device->backend_kind == LIBXL__DEVICE_KIND_VBD);
>> break;
>> + case LIBXL_DISK_BACKEND_STANDALONE:
>> + dev = disk->pdev_path;
>> +
>> + flexarray_append(back, "params");
>> + flexarray_append(back, dev);
>>
>> + assert(device->backend_kind ==
>> LIBXL__DEVICE_KIND_VIRTIO_DISK);
>> + break;
>> case LIBXL_DISK_BACKEND_TAP:
>> LOG(ERROR, "blktap is not supported");
>> rc = ERROR_FAIL;
>> @@ -387,6 +422,14 @@ static void device_disk_add(libxl__egc *egc,
>> uint32_t domid,
>> flexarray_append_pair(back, "discard-enable",
>> libxl_defbool_val(disk->discard_enable) ?
>> "1" : "0");
>> + flexarray_append(back, "specification");
>> + flexarray_append(back,
>> libxl__device_disk_string_of_specification(disk-
>>> specification));
>> + if (disk->specification == LIBXL_DISK_SPECIFICATION_VIRTIO) {
>> + flexarray_append(back, "transport");
>> + flexarray_append(back,
>> libxl__device_disk_string_of_transport(disk-
>>> transport));
>> + flexarray_append_pair(back, "base", GCSPRINTF("%"PRIu64, disk-
>>> base));
>> + flexarray_append_pair(back, "irq", GCSPRINTF("%u", disk->irq));
>> + }
>>
>> flexarray_append(front, "backend-id");
>> flexarray_append(front, GCSPRINTF("%d", disk->backend_domid));
>> @@ -535,6 +578,53 @@ static int libxl__disk_from_xenstore(libxl__gc *gc,
>> const char *libxl_path,
>> }
>> libxl_string_to_backend(ctx, tmp, &(disk->backend));
>>
>> + tmp = libxl__xs_read(gc, XBT_NULL,
>> + GCSPRINTF("%s/specification", libxl_path));
>> + if (!tmp) {
>> + LOG(DEBUG, "Missing xenstore node %s/specification, assuming
>> specification xen", libxl_path);
>> + disk->specification = LIBXL_DISK_SPECIFICATION_XEN;
>> + } else {
>> + rc = libxl_disk_specification_from_string(tmp,
>> &disk->specification);
>> + if (rc) {
>> + LOG(ERROR, "Unable to parse xenstore node %s/specification",
>> libxl_path);
>> + goto cleanup;
>> + }
>> + }
>> +
>> + if (disk->specification == LIBXL_DISK_SPECIFICATION_VIRTIO) {
>> + tmp = libxl__xs_read(gc, XBT_NULL,
>> + GCSPRINTF("%s/transport", libxl_path));
>> + if (!tmp) {
>> + LOG(ERROR, "Missing xenstore node %s/transport", libxl_path);
>> + goto cleanup;
>> + }
>> + rc = libxl_disk_transport_from_string(tmp, &disk->transport);
>> + if (rc) {
>> + LOG(ERROR, "Unable to parse xenstore node %s/transport",
>> libxl_path);
>> + goto cleanup;
>> + }
>> + if (disk->transport != LIBXL_DISK_TRANSPORT_MMIO) {
>> + LOG(ERROR, "Only transport mmio is expected for specification
>> virtio");
>> + goto cleanup;
>> + }
>> +
>> + tmp = libxl__xs_read(gc, XBT_NULL,
>> + GCSPRINTF("%s/base", libxl_path));
>> + if (!tmp) {
>> + LOG(ERROR, "Missing xenstore node %s/base", libxl_path);
>> + goto cleanup;
>> + }
>> + disk->base = strtoul(tmp, NULL, 10);
>> +
>> + tmp = libxl__xs_read(gc, XBT_NULL,
>> + GCSPRINTF("%s/irq", libxl_path));
>> + if (!tmp) {
>> + LOG(ERROR, "Missing xenstore node %s/irq", libxl_path);
>> + goto cleanup;
>> + }
>> + disk->irq = strtoul(tmp, NULL, 10);
>> + }
>> +
>> disk->vdev = xs_read(ctx->xsh, XBT_NULL,
>> GCSPRINTF("%s/dev", libxl_path), &len);
>> if (!disk->vdev) {
>> @@ -578,6 +668,42 @@ cleanup:
>> return rc;
>> }
>>
>> +static int libxl__device_disk_get_path(libxl__gc *gc, uint32_t domid,
>> + char **path)
>> +{
>> + const char *xen_dir, *virtio_dir;
>> + char *xen_path, *virtio_path;
>> + int rc;
>> +
>> + /* default path */
>> + xen_path = GCSPRINTF("%s/device/%s",
>> + libxl__xs_libxl_path(gc, domid),
>> +
>> libxl__device_kind_to_string(LIBXL__DEVICE_KIND_VBD));
>> +
>> + rc = libxl__xs_read_checked(gc, XBT_NULL, xen_path, &xen_dir);
>> + if (rc)
>> + return rc;
>> +
>> + virtio_path = GCSPRINTF("%s/device/%s",
>> + libxl__xs_libxl_path(gc, domid),
>> +
>> libxl__device_kind_to_string(LIBXL__DEVICE_KIND_VIRTIO_DISK));
>> +
>> + rc = libxl__xs_read_checked(gc, XBT_NULL, virtio_path, &virtio_dir);
>> + if (rc)
>> + return rc;
>> +
>> + if (xen_dir && virtio_dir) {
>> + LOGD(ERROR, domid, "Invalid configuration, both xen and virtio paths
>> are present");
>> + return ERROR_INVAL;
>> + } else if (virtio_dir) {
>> + *path = virtio_path;
>> + } else {
>> + *path = xen_path;
>> + }
>> +
>> + return 0;
>> +}
>> +
>> int libxl_vdev_to_device_disk(libxl_ctx *ctx, uint32_t domid,
>> const char *vdev, libxl_device_disk *disk)
>> {
>> @@ -591,10 +717,12 @@ int libxl_vdev_to_device_disk(libxl_ctx *ctx,
>> uint32_t domid,
>>
>> libxl_device_disk_init(disk);
>>
>> - libxl_path = libxl__domain_device_libxl_path(gc, domid, devid,
>> - LIBXL__DEVICE_KIND_VBD);
>> + rc = libxl__device_disk_get_path(gc, domid, &libxl_path);
>> + if (rc)
>> + return rc;
>>
>> - rc = libxl__disk_from_xenstore(gc, libxl_path, devid, disk);
>> + rc = libxl__disk_from_xenstore(gc, GCSPRINTF("%s/%d", libxl_path,
>> devid),
>> + devid, disk);
>>
>> GC_FREE;
>> return rc;
>> @@ -608,16 +736,19 @@ int libxl_device_disk_getinfo(libxl_ctx *ctx,
>> uint32_t domid,
>> char *fe_path, *libxl_path;
>> char *val;
>> int rc;
>> + libxl__device_kind kind;
>>
>> diskinfo->backend = NULL;
>>
>> diskinfo->devid = libxl__device_disk_dev_number(disk->vdev, NULL,
>> NULL);
>>
>> - /* tap devices entries in xenstore are written as vbd devices. */
>> + /* tap devices entries in xenstore are written as vbd/virtio_disk
>> devices.
>> */
>> + kind = disk->backend == LIBXL_DISK_BACKEND_STANDALONE ?
>> + LIBXL__DEVICE_KIND_VIRTIO_DISK : LIBXL__DEVICE_KIND_VBD;
>> fe_path = libxl__domain_device_frontend_path(gc, domid, diskinfo-
>>> devid,
>> - LIBXL__DEVICE_KIND_VBD);
>> + kind);
>> libxl_path = libxl__domain_device_libxl_path(gc, domid,
>> diskinfo->devid,
>> - LIBXL__DEVICE_KIND_VBD);
>> + kind);
>> diskinfo->backend = xs_read(ctx->xsh, XBT_NULL,
>> GCSPRINTF("%s/backend", libxl_path), NULL);
>> if (!diskinfo->backend) {
>> @@ -1421,6 +1552,7 @@ LIBXL_DEFINE_DEVICE_LIST(disk)
>> #define libxl__device_disk_update_devid NULL
>>
>> DEFINE_DEVICE_TYPE_STRUCT(disk, VBD, disks,
>> + .get_path = libxl__device_disk_get_path,
>> .merge = libxl_device_disk_merge,
>> .dm_needed = libxl_device_disk_dm_needed,
>> .from_xenstore = (device_from_xenstore_fn_t)libxl__disk_from_xenstore,
>> diff --git a/tools/libs/light/libxl_internal.h
>> b/tools/libs/light/libxl_internal.h
>> index bdef5a605e..cb9e8b3b8b 100644
>> --- a/tools/libs/light/libxl_internal.h
>> +++ b/tools/libs/light/libxl_internal.h
>> @@ -1493,6 +1493,8 @@ _hidden char *
>> libxl__domain_pvcontrol_read(libxl__gc *gc,
>>
>> /* from xl_device */
>> _hidden char *libxl__device_disk_string_of_backend(libxl_disk_backend
>> backend);
>> +_hidden char
>> *libxl__device_disk_string_of_specification(libxl_disk_specification
>> specification);
>> +_hidden char *libxl__device_disk_string_of_transport(libxl_disk_transport
>> transport);
>> _hidden char *libxl__device_disk_string_of_format(libxl_disk_format
>> format);
>> _hidden const char *libxl__qemu_disk_format_string(libxl_disk_format
>> format);
>> _hidden int libxl__device_disk_set_backend(libxl__gc*, libxl_device_disk*);
>> diff --git a/tools/libs/light/libxl_types.idl
>> b/tools/libs/light/libxl_types.idl
>> index f3ceb38c9e..d634f304cd 100644
>> --- a/tools/libs/light/libxl_types.idl
>> +++ b/tools/libs/light/libxl_types.idl
>> @@ -130,6 +130,18 @@ libxl_disk_backend = Enumeration("disk_backend",
>> [
>> (1, "PHY"),
>> (2, "TAP"),
>> (3, "QDISK"),
>> + (4, "STANDALONE"), # Only relying on the Xenstore data
>> + ])
>> +
>> +libxl_disk_specification = Enumeration("disk_specification", [
>> + (0, "UNKNOWN"),
>> + (1, "XEN"),
>> + (2, "VIRTIO"),
>> + ])
>> +
>> +libxl_disk_transport = Enumeration("disk_transport", [
>> + (0, "UNKNOWN"),
>> + (1, "MMIO"),
>> ])
>>
>> libxl_nic_type = Enumeration("nic_type", [
>> @@ -706,6 +718,12 @@ libxl_device_disk = Struct("device_disk", [
>> ("is_cdrom", integer),
>> ("direct_io_safe", bool),
>> ("discard_enable", libxl_defbool),
>> + ("specification", libxl_disk_specification),
>> + ("transport", libxl_disk_transport),
>> + # Note that virtio-mmio parameters (irq and base) are for internal use
>> + # by libxl and can't be modified.
>> + ("irq", uint32),
>> + ("base", uint64),
>> # Note that the COLO configuration settings should be considered
>> unstable.
>> # They may change incompatibly in future versions of Xen.
>> ("colo_enable", libxl_defbool),
>> diff --git a/tools/libs/light/libxl_types_internal.idl
>> b/tools/libs/light/libxl_types_internal.idl
>> index 3593e21dbb..8f71980aec 100644
>> --- a/tools/libs/light/libxl_types_internal.idl
>> +++ b/tools/libs/light/libxl_types_internal.idl
>> @@ -32,6 +32,7 @@ libxl__device_kind = Enumeration("device_kind", [
>> (14, "PVCALLS"),
>> (15, "VSND"),
>> (16, "VINPUT"),
>> + (17, "VIRTIO_DISK"),
>> ])
>>
>> libxl__console_backend = Enumeration("console_backend", [
>> diff --git a/tools/libs/light/libxl_utils.c b/tools/libs/light/libxl_utils.c
>> index e5e6b2da96..e403bd9bcf 100644
>> --- a/tools/libs/light/libxl_utils.c
>> +++ b/tools/libs/light/libxl_utils.c
>> @@ -297,6 +297,8 @@ int libxl_string_to_backend(libxl_ctx *ctx, char *s,
>> libxl_disk_backend *backend
>> *backend = LIBXL_DISK_BACKEND_TAP;
>> } else if (!strcmp(s, "qdisk")) {
>> *backend = LIBXL_DISK_BACKEND_QDISK;
>> + } else if (!strcmp(s, "standalone")) {
>> + *backend = LIBXL_DISK_BACKEND_STANDALONE;
>> } else if (!strcmp(s, "tap")) {
>> p = strchr(s, ':');
>> if (!p) {
>> diff --git a/tools/libs/util/libxlu_disk_l.c
>> b/tools/libs/util/libxlu_disk_l.c
>> index 32d4b74b58..0b59723b71 100644
>> --- a/tools/libs/util/libxlu_disk_l.c
>> +++ b/tools/libs/util/libxlu_disk_l.c
>> @@ -549,8 +549,8 @@ static void yynoreturn yy_fatal_error ( const char*
>> msg , yyscan_t yyscanner );
>> yyg->yy_hold_char = *yy_cp; \
>> *yy_cp = '\0'; \
>> yyg->yy_c_buf_p = yy_cp;
>> -#define YY_NUM_RULES 36
>> -#define YY_END_OF_BUFFER 37
>> +#define YY_NUM_RULES 37
>> +#define YY_END_OF_BUFFER 38
>> /* This struct is not used in this scanner,
>> but its presence is necessary. */
>> struct yy_trans_info
>> @@ -558,74 +558,77 @@ struct yy_trans_info
>> flex_int32_t yy_verify;
>> flex_int32_t yy_nxt;
>> };
>> -static const flex_int16_t yy_acclist[575] =
>> +static const flex_int16_t yy_acclist[594] =
>> { 0,
>> - 35, 35, 37, 33, 34, 36, 8193, 33, 34, 36,
>> - 16385, 8193, 33, 36,16385, 33, 34, 36, 34, 36,
>> - 33, 34, 36, 33, 34, 36, 33, 34, 36, 33,
>> - 34, 36, 33, 34, 36, 33, 34, 36, 33, 34,
>> - 36, 33, 34, 36, 33, 34, 36, 33, 34, 36,
>> - 33, 34, 36, 33, 34, 36, 33, 34, 36, 33,
>> - 34, 36, 33, 34, 36, 33, 34, 36, 35, 36,
>> - 36, 33, 33, 8193, 33, 8193, 33,16385, 8193, 33,
>> - 8193, 33, 33, 8224, 33,16416, 33, 33, 33, 33,
>> - 33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
>> -
>> - 33, 33, 33, 33, 33, 33, 33, 33, 33, 35,
>> - 8193, 33, 8193, 33, 8193, 8224, 33, 8224, 33, 8224,
>> - 23, 33, 33, 33, 33, 33, 33, 33, 33, 33,
>> - 33, 33, 33, 33, 33, 33, 33, 33, 33, 33,
>> - 33, 33, 33, 33, 33, 8224, 33, 8224, 33, 8224,
>> - 23, 33, 33, 28, 8224, 33,16416, 33, 33, 15,
>> - 33, 33, 33, 33, 33, 33, 33, 33, 33, 8217,
>> - 8224, 33,16409,16416, 33, 33, 31, 8224, 33,16416,
>> - 33, 8216, 8224, 33,16408,16416, 33, 33, 8219, 8224,
>> - 33,16411,16416, 33, 33, 33, 33, 33, 28, 8224,
>> -
>> - 33, 28, 8224, 33, 28, 33, 28, 8224, 33, 3,
>> - 33, 15, 33, 33, 33, 33, 33, 30, 8224, 33,
>> - 16416, 33, 33, 33, 8217, 8224, 33, 8217, 8224, 33,
>> - 8217, 33, 8217, 8224, 33, 33, 31, 8224, 33, 31,
>> - 8224, 33, 31, 33, 31, 8224, 8216, 8224, 33, 8216,
>> - 8224, 33, 8216, 33, 8216, 8224, 33, 8219, 8224, 33,
>> - 8219, 8224, 33, 8219, 33, 8219, 8224, 33, 33, 10,
>> - 33, 33, 28, 8224, 33, 28, 8224, 33, 28, 8224,
>> - 28, 33, 28, 33, 3, 33, 33, 33, 33, 33,
>> - 33, 33, 30, 8224, 33, 30, 8224, 33, 30, 33,
>> -
>> - 30, 8224, 33, 33, 29, 8224, 33,16416, 8217, 8224,
>> - 33, 8217, 8224, 33, 8217, 8224, 8217, 33, 8217, 33,
>> - 33, 31, 8224, 33, 31, 8224, 33, 31, 8224, 31,
>> - 33, 31, 8216, 8224, 33, 8216, 8224, 33, 8216, 8224,
>> - 8216, 33, 8216, 33, 8219, 8224, 33, 8219, 8224, 33,
>> - 8219, 8224, 8219, 33, 8219, 33, 33, 10, 23, 10,
>> - 7, 33, 33, 33, 33, 33, 33, 33, 13, 33,
>> - 30, 8224, 33, 30, 8224, 33, 30, 8224, 30, 33,
>> - 30, 2, 33, 29, 8224, 33, 29, 8224, 33, 29,
>> - 33, 29, 8224, 16, 33, 33, 11, 33, 22, 10,
>> -
>> - 10, 23, 7, 23, 7, 33, 8, 33, 33, 33,
>> - 33, 6, 33, 13, 33, 2, 23, 2, 33, 29,
>> - 8224, 33, 29, 8224, 33, 29, 8224, 29, 33, 29,
>> - 16, 33, 33, 11, 23, 11, 26, 8224, 33,16416,
>> - 22, 23, 22, 7, 7, 23, 33, 8, 23, 8,
>> - 33, 33, 33, 33, 6, 23, 6, 6, 23, 6,
>> - 23, 33, 2, 2, 23, 33, 33, 11, 11, 23,
>> - 26, 8224, 33, 26, 8224, 33, 26, 33, 26, 8224,
>> - 22, 23, 33, 8, 8, 23, 33, 33, 17, 18,
>> - 6, 6, 23, 6, 6, 33, 33, 14, 33, 26,
>> -
>> - 8224, 33, 26, 8224, 33, 26, 8224, 26, 33, 26,
>> - 33, 33, 33, 17, 23, 17, 18, 23, 18, 6,
>> - 6, 33, 33, 14, 33, 20, 9, 19, 17, 17,
>> - 23, 18, 18, 23, 6, 5, 6, 33, 21, 20,
>> - 23, 20, 9, 23, 9, 19, 23, 19, 4, 6,
>> - 5, 6, 33, 21, 23, 21, 20, 20, 23, 9,
>> - 9, 23, 19, 19, 23, 4, 6, 12, 33, 21,
>> - 21, 23, 12, 33
>> + 36, 36, 38, 34, 35, 37, 8193, 34, 35, 37,
>> + 16385, 8193, 34, 37,16385, 34, 35, 37, 35, 37,
>> + 34, 35, 37, 34, 35, 37, 34, 35, 37, 34,
>> + 35, 37, 34, 35, 37, 34, 35, 37, 34, 35,
>> + 37, 34, 35, 37, 34, 35, 37, 34, 35, 37,
>> + 34, 35, 37, 34, 35, 37, 34, 35, 37, 34,
>> + 35, 37, 34, 35, 37, 34, 35, 37, 36, 37,
>> + 37, 34, 34, 8193, 34, 8193, 34,16385, 8193, 34,
>> + 8193, 34, 34, 8225, 34,16417, 34, 34, 34, 34,
>> + 34, 34, 34, 34, 34, 34, 34, 34, 34, 34,
>> +
>> + 34, 34, 34, 34, 34, 34, 34, 34, 34, 34,
>> + 36, 8193, 34, 8193, 34, 8193, 8225, 34, 8225, 34,
>> + 8225, 24, 34, 34, 34, 34, 34, 34, 34, 34,
>> + 34, 34, 34, 34, 34, 34, 34, 34, 34, 34,
>> + 34, 34, 34, 34, 34, 34, 34, 8225, 34, 8225,
>> + 34, 8225, 24, 34, 34, 29, 8225, 34,16417, 34,
>> + 34, 16, 34, 34, 34, 34, 34, 34, 34, 34,
>> + 34, 8218, 8225, 34,16410,16417, 34, 34, 32, 8225,
>> + 34,16417, 34, 8217, 8225, 34,16409,16417, 34, 34,
>> + 34, 8220, 8225, 34,16412,16417, 34, 34, 34, 34,
>> +
>> + 34, 29, 8225, 34, 29, 8225, 34, 29, 34, 29,
>> + 8225, 34, 3, 34, 16, 34, 34, 34, 34, 34,
>> + 31, 8225, 34,16417, 34, 34, 34, 8218, 8225, 34,
>> + 8218, 8225, 34, 8218, 34, 8218, 8225, 34, 34, 32,
>> + 8225, 34, 32, 8225, 34, 32, 34, 32, 8225, 8217,
>> + 8225, 34, 8217, 8225, 34, 8217, 34, 8217, 8225, 34,
>> + 34, 8220, 8225, 34, 8220, 8225, 34, 8220, 34, 8220,
>> + 8225, 34, 34, 11, 34, 34, 29, 8225, 34, 29,
>> + 8225, 34, 29, 8225, 29, 34, 29, 34, 3, 34,
>> + 34, 34, 34, 34, 34, 34, 31, 8225, 34, 31,
>> +
>> + 8225, 34, 31, 34, 31, 8225, 34, 34, 30, 8225,
>> + 34,16417, 8218, 8225, 34, 8218, 8225, 34, 8218, 8225,
>> + 8218, 34, 8218, 34, 34, 32, 8225, 34, 32, 8225,
>> + 34, 32, 8225, 32, 34, 32, 8217, 8225, 34, 8217,
>> + 8225, 34, 8217, 8225, 8217, 34, 8217, 34, 34, 8220,
>> + 8225, 34, 8220, 8225, 34, 8220, 8225, 8220, 34, 8220,
>> + 34, 34, 11, 24, 11, 7, 34, 34, 34, 34,
>> + 34, 34, 34, 14, 34, 31, 8225, 34, 31, 8225,
>> + 34, 31, 8225, 31, 34, 31, 2, 34, 30, 8225,
>> + 34, 30, 8225, 34, 30, 34, 30, 8225, 17, 34,
>> +
>> + 34, 12, 34, 34, 23, 11, 11, 24, 7, 24,
>> + 7, 34, 8, 34, 34, 34, 34, 6, 34, 14,
>> + 34, 2, 24, 2, 34, 30, 8225, 34, 30, 8225,
>> + 34, 30, 8225, 30, 34, 30, 17, 34, 34, 12,
>> + 24, 12, 34, 27, 8225, 34,16417, 23, 24, 23,
>> + 7, 7, 24, 34, 8, 24, 8, 34, 34, 34,
>> + 34, 6, 24, 6, 6, 24, 6, 24, 34, 2,
>> + 2, 24, 34, 34, 12, 12, 24, 34, 27, 8225,
>> + 34, 27, 8225, 34, 27, 34, 27, 8225, 23, 24,
>> + 34, 8, 8, 24, 34, 34, 18, 19, 6, 6,
>> +
>> + 24, 6, 6, 34, 34, 15, 34, 34, 27, 8225,
>> + 34, 27, 8225, 34, 27, 8225, 27, 34, 27, 34,
>> + 34, 34, 18, 24, 18, 19, 24, 19, 6, 6,
>> + 34, 34, 15, 34, 34, 21, 9, 20, 18, 18,
>> + 24, 19, 19, 24, 6, 5, 6, 34, 22, 34,
>> + 21, 24, 21, 9, 24, 9, 20, 24, 20, 4,
>> + 6, 5, 6, 34, 22, 24, 22, 34, 21, 21,
>> + 24, 9, 9, 24, 20, 20, 24, 4, 6, 13,
>> + 34, 22, 22, 24, 10, 13, 34, 10, 24, 10,
>> + 10, 10, 24
>> +
>> } ;
>>
>> -static const flex_int16_t yy_accept[356] =
>> +static const flex_int16_t yy_accept[373] =
>> { 0,
>> 1, 1, 1, 2, 3, 4, 7, 12, 16, 19,
>> 21, 24, 27, 30, 33, 36, 39, 42, 45, 48,
>> @@ -633,39 +636,41 @@ static const flex_int16_t yy_accept[356] =
>> 74, 76, 79, 81, 82, 83, 84, 87, 87, 88,
>> 89, 90, 91, 92, 93, 94, 95, 96, 97, 98,
>> 99, 100, 101, 102, 103, 104, 105, 106, 107, 108,
>> - 109, 110, 111, 113, 115, 116, 118, 120, 121, 122,
>> + 109, 110, 111, 112, 114, 116, 117, 119, 121, 122,
>> 123, 124, 125, 126, 127, 128, 129, 130, 131, 132,
>> 133, 134, 135, 136, 137, 138, 139, 140, 141, 142,
>> - 143, 144, 145, 146, 148, 150, 151, 152, 153, 154,
>> -
>> - 158, 159, 160, 162, 163, 164, 165, 166, 167, 168,
>> - 169, 170, 175, 176, 177, 181, 182, 187, 188, 189,
>> - 194, 195, 196, 197, 198, 199, 202, 205, 207, 209,
>> - 210, 212, 214, 215, 216, 217, 218, 222, 223, 224,
>> - 225, 228, 231, 233, 235, 236, 237, 240, 243, 245,
>> - 247, 250, 253, 255, 257, 258, 261, 264, 266, 268,
>> - 269, 270, 271, 272, 273, 276, 279, 281, 283, 284,
>> - 285, 287, 288, 289, 290, 291, 292, 293, 296, 299,
>> - 301, 303, 304, 305, 309, 312, 315, 317, 319, 320,
>> - 321, 322, 325, 328, 330, 332, 333, 336, 339, 341,
>> -
>> - 343, 344, 345, 348, 351, 353, 355, 356, 357, 358,
>> - 360, 361, 362, 363, 364, 365, 366, 367, 368, 369,
>> - 371, 374, 377, 379, 381, 382, 383, 384, 387, 390,
>> - 392, 394, 396, 397, 398, 399, 400, 401, 403, 405,
>> - 406, 407, 408, 409, 410, 411, 412, 413, 414, 416,
>> - 418, 419, 420, 423, 426, 428, 430, 431, 433, 434,
>> - 436, 437, 441, 443, 444, 445, 447, 448, 450, 451,
>> - 452, 453, 454, 455, 457, 458, 460, 462, 463, 464,
>> - 466, 467, 468, 469, 471, 474, 477, 479, 481, 483,
>> - 484, 485, 487, 488, 489, 490, 491, 492, 494, 495,
>> -
>> - 496, 497, 498, 500, 503, 506, 508, 510, 511, 512,
>> - 513, 514, 516, 517, 519, 520, 521, 522, 523, 524,
>> - 526, 527, 528, 529, 530, 532, 533, 535, 536, 538,
>> - 539, 540, 542, 543, 545, 546, 548, 549, 551, 553,
>> - 554, 556, 557, 558, 560, 561, 563, 564, 566, 568,
>> - 570, 571, 573, 575, 575
>> + 143, 144, 145, 146, 147, 148, 150, 152, 153, 154,
>> +
>> + 155, 156, 160, 161, 162, 164, 165, 166, 167, 168,
>> + 169, 170, 171, 172, 177, 178, 179, 183, 184, 189,
>> + 190, 191, 192, 197, 198, 199, 200, 201, 202, 205,
>> + 208, 210, 212, 213, 215, 217, 218, 219, 220, 221,
>> + 225, 226, 227, 228, 231, 234, 236, 238, 239, 240,
>> + 243, 246, 248, 250, 253, 256, 258, 260, 261, 262,
>> + 265, 268, 270, 272, 273, 274, 275, 276, 277, 280,
>> + 283, 285, 287, 288, 289, 291, 292, 293, 294, 295,
>> + 296, 297, 300, 303, 305, 307, 308, 309, 313, 316,
>> + 319, 321, 323, 324, 325, 326, 329, 332, 334, 336,
>> +
>> + 337, 340, 343, 345, 347, 348, 349, 350, 353, 356,
>> + 358, 360, 361, 362, 363, 365, 366, 367, 368, 369,
>> + 370, 371, 372, 373, 374, 376, 379, 382, 384, 386,
>> + 387, 388, 389, 392, 395, 397, 399, 401, 402, 403,
>> + 404, 405, 406, 407, 409, 411, 412, 413, 414, 415,
>> + 416, 417, 418, 419, 420, 422, 424, 425, 426, 429,
>> + 432, 434, 436, 437, 439, 440, 442, 443, 444, 448,
>> + 450, 451, 452, 454, 455, 457, 458, 459, 460, 461,
>> + 462, 464, 465, 467, 469, 470, 471, 473, 474, 475,
>> + 476, 478, 479, 482, 485, 487, 489, 491, 492, 493,
>> +
>> + 495, 496, 497, 498, 499, 500, 502, 503, 504, 505,
>> + 506, 508, 509, 512, 515, 517, 519, 520, 521, 522,
>> + 523, 525, 526, 528, 529, 530, 531, 532, 533, 535,
>> + 536, 537, 538, 539, 540, 542, 543, 545, 546, 548,
>> + 549, 550, 551, 553, 554, 556, 557, 559, 560, 562,
>> + 564, 565, 567, 568, 569, 570, 572, 573, 575, 576,
>> + 578, 580, 582, 583, 585, 586, 588, 590, 591, 592,
>> + 594, 594
>> } ;
>>
>> static const YY_CHAR yy_ec[256] =
>> @@ -708,216 +713,224 @@ static const YY_CHAR yy_meta[35] =
>> 1, 1, 1, 1
>> } ;
>>
>> -static const flex_int16_t yy_base[424] =
>> +static const flex_int16_t yy_base[443] =
>> { 0,
>> - 0, 0, 901, 900, 902, 897, 33, 36, 905, 905,
>> - 45, 63, 31, 42, 51, 52, 890, 33, 65, 67,
>> - 69, 70, 889, 71, 888, 75, 0, 905, 893, 905,
>> - 91, 94, 0, 0, 103, 886, 112, 0, 89, 98,
>> - 113, 92, 114, 99, 100, 48, 121, 116, 119, 74,
>> - 124, 129, 123, 135, 132, 133, 137, 134, 138, 139,
>> - 141, 0, 155, 0, 0, 164, 0, 0, 849, 142,
>> - 152, 164, 140, 161, 165, 166, 167, 168, 169, 173,
>> - 174, 178, 176, 180, 184, 208, 189, 183, 192, 195,
>> - 215, 191, 193, 223, 0, 0, 905, 208, 204, 236,
>> -
>> - 219, 209, 238, 196, 237, 831, 242, 815, 241, 224,
>> - 243, 261, 244, 259, 277, 266, 286, 250, 288, 298,
>> - 249, 283, 274, 282, 294, 308, 0, 310, 0, 295,
>> - 305, 905, 308, 306, 313, 314, 342, 319, 316, 320,
>> - 331, 0, 349, 0, 342, 344, 356, 0, 358, 0,
>> - 365, 0, 367, 0, 354, 375, 0, 377, 0, 363,
>> - 356, 809, 327, 322, 384, 0, 0, 0, 0, 379,
>> - 905, 382, 384, 386, 390, 372, 392, 403, 0, 410,
>> - 0, 407, 413, 423, 426, 0, 0, 0, 0, 409,
>> - 424, 435, 0, 0, 0, 0, 437, 0, 0, 0,
>> -
>> - 0, 433, 444, 0, 0, 0, 0, 391, 440, 781,
>> - 905, 769, 439, 445, 444, 447, 449, 454, 453, 399,
>> - 464, 0, 0, 0, 0, 757, 465, 476, 0, 478,
>> - 0, 479, 476, 753, 462, 490, 749, 905, 745, 905,
>> - 483, 737, 424, 485, 487, 490, 500, 493, 905, 729,
>> - 905, 502, 518, 0, 0, 0, 0, 905, 498, 721,
>> - 905, 527, 713, 0, 705, 905, 495, 697, 905, 365,
>> - 521, 528, 530, 685, 905, 534, 540, 540, 657, 905,
>> - 537, 542, 650, 905, 553, 0, 557, 0, 0, 551,
>> - 641, 905, 558, 557, 633, 614, 613, 905, 547, 555,
>> -
>> - 563, 565, 569, 584, 0, 0, 0, 0, 583, 570,
>> - 585, 612, 905, 601, 905, 522, 580, 589, 594, 905,
>> - 600, 585, 563, 520, 905, 514, 905, 586, 486, 597,
>> - 480, 441, 905, 416, 905, 345, 905, 334, 905, 601,
>> - 254, 905, 242, 905, 200, 905, 151, 905, 905, 607,
>> - 86, 905, 905, 905, 620, 624, 627, 631, 635, 639,
>> - 643, 647, 651, 655, 659, 663, 667, 671, 675, 679,
>> - 683, 687, 691, 695, 699, 703, 707, 711, 715, 719,
>> - 723, 727, 731, 735, 739, 743, 747, 751, 755, 759,
>> - 763, 767, 771, 775, 779, 783, 787, 791, 795, 799,
>> -
>> - 803, 807, 811, 815, 819, 823, 827, 831, 835, 839,
>> - 843, 847, 851, 855, 859, 863, 867, 871, 875, 879,
>> - 883, 887, 891
>> + 0, 0, 936, 935, 937, 932, 33, 36, 940, 940,
>> + 45, 63, 31, 42, 51, 52, 925, 33, 65, 67,
>> + 69, 70, 924, 71, 923, 75, 0, 940, 928, 940,
>> + 91, 95, 0, 0, 104, 921, 113, 0, 91, 99,
>> + 114, 92, 115, 80, 100, 48, 119, 121, 122, 74,
>> + 123, 128, 131, 129, 125, 133, 135, 136, 137, 143,
>> + 138, 145, 0, 157, 0, 0, 168, 0, 0, 926,
>> + 140, 146, 165, 159, 152, 164, 155, 168, 171, 176,
>> + 177, 170, 180, 175, 184, 188, 212, 191, 185, 192,
>> + 193, 194, 219, 212, 199, 230, 0, 0, 940, 195,
>> +
>> + 200, 239, 235, 197, 246, 225, 226, 919, 244, 918,
>> + 243, 236, 245, 266, 248, 264, 282, 271, 291, 248,
>> + 270, 254, 300, 279, 296, 302, 288, 303, 311, 0,
>> + 315, 0, 311, 318, 940, 313, 319, 208, 313, 344,
>> + 321, 331, 325, 333, 0, 352, 0, 345, 347, 359,
>> + 0, 361, 0, 368, 0, 370, 0, 322, 366, 379,
>> + 0, 381, 0, 359, 357, 923, 382, 384, 392, 0,
>> + 0, 0, 0, 387, 940, 386, 390, 392, 329, 401,
>> + 397, 409, 0, 417, 0, 399, 412, 426, 429, 0,
>> + 0, 0, 0, 412, 427, 438, 0, 0, 0, 0,
>> +
>> + 440, 0, 0, 0, 0, 436, 405, 447, 0, 0,
>> + 0, 0, 438, 443, 922, 940, 921, 442, 450, 449,
>> + 452, 454, 459, 458, 453, 469, 0, 0, 0, 0,
>> + 920, 470, 481, 0, 483, 0, 484, 481, 919, 368,
>> + 467, 495, 918, 940, 917, 940, 488, 916, 479, 490,
>> + 492, 495, 505, 498, 940, 915, 940, 507, 523, 0,
>> + 0, 0, 0, 940, 503, 864, 940, 846, 532, 836,
>> + 0, 824, 940, 516, 796, 940, 513, 530, 536, 538,
>> + 784, 940, 542, 535, 547, 772, 940, 549, 551, 768,
>> + 940, 502, 562, 0, 564, 0, 0, 562, 764, 940,
>> +
>> + 544, 557, 760, 752, 744, 940, 552, 568, 571, 568,
>> + 581, 577, 588, 0, 0, 0, 0, 589, 580, 591,
>> + 736, 940, 728, 940, 601, 602, 597, 599, 940, 603,
>> + 720, 712, 700, 672, 940, 665, 940, 610, 656, 603,
>> + 648, 607, 629, 940, 627, 940, 625, 940, 624, 940,
>> + 607, 574, 940, 614, 572, 940, 491, 940, 433, 940,
>> + 940, 622, 389, 940, 303, 940, 261, 940, 204, 940,
>> + 940, 635, 639, 642, 646, 650, 654, 658, 662, 666,
>> + 670, 674, 678, 682, 686, 690, 694, 698, 702, 706,
>> + 710, 714, 718, 722, 726, 730, 734, 738, 742, 746,
>> +
>> + 750, 754, 758, 762, 766, 770, 774, 778, 782, 786,
>> + 790, 794, 798, 802, 806, 810, 814, 818, 822, 826,
>> + 830, 834, 838, 842, 846, 850, 854, 858, 862, 866,
>> + 870, 874, 878, 882, 886, 890, 894, 898, 902, 906,
>> + 910, 914
>> } ;
>>
>> -static const flex_int16_t yy_def[424] =
>> +static const flex_int16_t yy_def[443] =
>> { 0,
>> - 354, 1, 355, 355, 354, 356, 357, 357, 354, 354,
>> - 358, 358, 12, 12, 12, 12, 12, 12, 12, 12,
>> - 12, 12, 12, 12, 12, 12, 359, 354, 356, 354,
>> - 360, 357, 361, 361, 362, 12, 356, 363, 12, 12,
>> - 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
>> + 371, 1, 372, 372, 371, 373, 374, 374, 371, 371,
>> + 375, 375, 12, 12, 12, 12, 12, 12, 12, 12,
>> + 12, 12, 12, 12, 12, 12, 376, 371, 373, 371,
>> + 377, 374, 378, 378, 379, 12, 373, 380, 12, 12,
>> 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
>> - 12, 359, 360, 361, 361, 364, 365, 365, 354, 12,
>> 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
>> - 12, 12, 12, 12, 12, 362, 12, 12, 12, 12,
>> - 12, 12, 12, 364, 365, 365, 354, 12, 12, 366,
>> -
>> + 12, 12, 376, 377, 378, 378, 381, 382, 382, 371,
>> 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
>> - 12, 367, 86, 86, 368, 12, 369, 12, 12, 370,
>> - 12, 12, 12, 12, 12, 371, 372, 366, 372, 12,
>> - 12, 354, 86, 12, 12, 12, 373, 12, 12, 12,
>> - 374, 375, 367, 375, 86, 86, 376, 377, 368, 377,
>> - 378, 379, 369, 379, 12, 380, 381, 370, 381, 12,
>> - 12, 382, 12, 12, 371, 372, 372, 383, 383, 12,
>> - 354, 86, 86, 86, 12, 12, 12, 384, 385, 373,
>> - 385, 12, 12, 386, 374, 375, 375, 387, 387, 86,
>> - 86, 376, 377, 377, 388, 388, 378, 379, 379, 389,
>> -
>> - 389, 12, 380, 381, 381, 390, 390, 12, 12, 391,
>> - 354, 392, 86, 12, 86, 86, 86, 12, 86, 12,
>> - 384, 385, 385, 393, 393, 394, 86, 395, 396, 386,
>> - 396, 86, 86, 397, 12, 398, 391, 354, 399, 354,
>> - 86, 400, 12, 86, 86, 86, 401, 86, 354, 402,
>> - 354, 86, 395, 396, 396, 403, 403, 354, 86, 404,
>> - 354, 405, 406, 406, 399, 354, 86, 407, 354, 12,
>> - 86, 86, 86, 408, 354, 408, 408, 86, 402, 354,
>> - 86, 86, 404, 354, 409, 410, 405, 410, 406, 86,
>> - 407, 354, 12, 86, 411, 412, 408, 354, 408, 408,
>> -
>> - 86, 86, 86, 409, 410, 410, 413, 413, 86, 12,
>> - 86, 414, 354, 415, 354, 408, 408, 86, 86, 354,
>> - 416, 417, 418, 414, 354, 415, 354, 408, 408, 86,
>> - 419, 420, 354, 421, 354, 422, 354, 408, 354, 86,
>> - 423, 354, 420, 354, 421, 354, 422, 354, 354, 86,
>> - 423, 354, 354, 0, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> -
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354
>> + 12, 12, 12, 12, 12, 12, 379, 12, 12, 12,
>> + 12, 12, 12, 12, 12, 381, 382, 382, 371, 12,
>> +
>> + 12, 383, 12, 12, 12, 12, 12, 12, 12, 12,
>> + 12, 12, 12, 384, 87, 87, 385, 12, 386, 12,
>> + 12, 12, 387, 12, 12, 12, 12, 12, 388, 389,
>> + 383, 389, 12, 12, 371, 87, 12, 12, 12, 390,
>> + 12, 12, 12, 391, 392, 384, 392, 87, 87, 393,
>> + 394, 385, 394, 395, 396, 386, 396, 12, 12, 397,
>> + 398, 387, 398, 12, 12, 399, 12, 12, 388, 389,
>> + 389, 400, 400, 12, 371, 87, 87, 87, 12, 12,
>> + 12, 401, 402, 390, 402, 12, 12, 403, 391, 392,
>> + 392, 404, 404, 87, 87, 393, 394, 394, 405, 405,
>> +
>> + 395, 396, 396, 406, 406, 12, 12, 397, 398, 398,
>> + 407, 407, 12, 12, 408, 371, 409, 87, 12, 87,
>> + 87, 87, 12, 87, 12, 401, 402, 402, 410, 410,
>> + 411, 87, 412, 413, 403, 413, 87, 87, 414, 12,
>> + 12, 415, 408, 371, 416, 371, 87, 417, 12, 87,
>> + 87, 87, 418, 87, 371, 419, 371, 87, 412, 413,
>> + 413, 420, 420, 371, 87, 421, 371, 12, 422, 423,
>> + 423, 416, 371, 87, 424, 371, 12, 87, 87, 87,
>> + 425, 371, 425, 425, 87, 419, 371, 87, 87, 421,
>> + 371, 12, 426, 427, 422, 427, 423, 87, 424, 371,
>> +
>> + 12, 87, 428, 429, 425, 371, 425, 425, 87, 87,
>> + 87, 12, 426, 427, 427, 430, 430, 87, 12, 87,
>> + 431, 371, 432, 371, 425, 425, 87, 87, 371, 12,
>> + 433, 434, 435, 431, 371, 432, 371, 425, 425, 87,
>> + 436, 12, 437, 371, 438, 371, 439, 371, 425, 371,
>> + 87, 440, 371, 12, 437, 371, 438, 371, 439, 371,
>> + 371, 87, 440, 371, 441, 371, 442, 371, 442, 371,
>> + 0, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> +
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371
>> } ;
>>
>> -static const flex_int16_t yy_nxt[940] =
>> +static const flex_int16_t yy_nxt[975] =
>> { 0,
>> 6, 7, 8, 9, 6, 6, 6, 6, 10, 11,
>> 12, 13, 14, 15, 16, 17, 18, 19, 17, 17,
>> 17, 17, 20, 17, 21, 22, 23, 24, 25, 17,
>> 26, 17, 17, 17, 32, 32, 33, 32, 32, 33,
>> 36, 34, 36, 42, 34, 29, 29, 29, 30, 35,
>> - 50, 36, 37, 38, 43, 44, 39, 36, 79, 45,
>> + 50, 36, 37, 38, 43, 44, 39, 36, 80, 45,
>> 36, 36, 40, 29, 29, 29, 30, 35, 46, 48,
>> 37, 38, 41, 47, 36, 49, 36, 53, 36, 36,
>> - 36, 56, 58, 36, 36, 55, 82, 60, 51, 342,
>> - 54, 61, 52, 29, 64, 32, 32, 33, 36, 65,
>> -
>> - 70, 36, 34, 29, 29, 29, 30, 36, 36, 36,
>> - 29, 38, 66, 66, 66, 67, 66, 71, 74, 66,
>> - 68, 72, 36, 36, 73, 36, 77, 78, 36, 76,
>> - 36, 53, 36, 36, 75, 85, 80, 83, 36, 86,
>> - 84, 36, 36, 36, 36, 81, 36, 36, 36, 36,
>> - 36, 36, 93, 89, 337, 98, 88, 29, 64, 101,
>> - 90, 36, 91, 65, 92, 87, 29, 95, 89, 99,
>> - 36, 100, 96, 36, 36, 36, 36, 36, 36, 106,
>> - 105, 85, 36, 36, 102, 36, 107, 36, 103, 36,
>> - 109, 112, 36, 36, 104, 108, 115, 110, 36, 117,
>> -
>> - 36, 36, 36, 335, 36, 36, 122, 111, 29, 29,
>> - 29, 30, 118, 36, 116, 29, 38, 36, 36, 113,
>> - 114, 119, 120, 123, 36, 29, 95, 121, 36, 134,
>> - 131, 96, 130, 36, 125, 124, 126, 126, 66, 127,
>> - 126, 132, 133, 126, 129, 333, 36, 36, 135, 137,
>> - 36, 36, 36, 140, 139, 35, 35, 352, 36, 36,
>> - 85, 141, 141, 66, 142, 141, 160, 145, 141, 144,
>> - 35, 35, 89, 117, 155, 36, 146, 147, 147, 66,
>> - 148, 147, 162, 36, 147, 150, 151, 151, 66, 152,
>> - 151, 36, 36, 151, 154, 120, 161, 36, 156, 156,
>> -
>> - 66, 157, 156, 36, 36, 156, 159, 164, 171, 163,
>> - 29, 166, 29, 168, 36, 36, 167, 170, 169, 35,
>> - 35, 172, 36, 36, 173, 36, 213, 184, 36, 36,
>> - 175, 36, 174, 29, 186, 212, 36, 349, 183, 187,
>> - 177, 176, 178, 178, 66, 179, 178, 182, 348, 178,
>> - 181, 29, 188, 35, 35, 35, 35, 189, 29, 193,
>> - 29, 195, 190, 36, 194, 36, 196, 29, 198, 29,
>> - 200, 191, 36, 199, 36, 201, 219, 29, 204, 29,
>> - 206, 36, 202, 205, 209, 207, 29, 166, 36, 293,
>> - 208, 214, 167, 35, 35, 35, 35, 35, 35, 36,
>> -
>> - 36, 36, 249, 218, 220, 29, 222, 216, 36, 217,
>> - 235, 223, 29, 224, 215, 226, 36, 227, 225, 346,
>> - 35, 35, 36, 228, 228, 66, 229, 228, 29, 186,
>> - 228, 231, 232, 36, 187, 233, 35, 29, 193, 29,
>> - 198, 234, 36, 194, 344, 199, 29, 204, 236, 36,
>> - 35, 241, 205, 242, 36, 35, 35, 270, 35, 35,
>> - 35, 35, 247, 36, 35, 35, 29, 222, 244, 262,
>> - 248, 36, 223, 243, 245, 246, 35, 252, 29, 254,
>> - 29, 256, 258, 342, 255, 259, 257, 35, 35, 339,
>> - 35, 35, 69, 264, 35, 35, 35, 35, 35, 35,
>> -
>> - 267, 35, 35, 275, 35, 35, 35, 35, 271, 35,
>> - 35, 276, 277, 35, 35, 272, 278, 315, 273, 281,
>> - 29, 254, 290, 313, 282, 275, 255, 285, 285, 66,
>> - 286, 285, 35, 35, 285, 288, 295, 298, 296, 35,
>> - 35, 35, 35, 298, 301, 328, 299, 294, 35, 35,
>> - 275, 35, 35, 35, 303, 29, 305, 300, 275, 29,
>> - 307, 306, 35, 35, 302, 308, 337, 36, 35, 35,
>> - 309, 310, 320, 316, 35, 35, 35, 35, 322, 36,
>> - 35, 35, 317, 275, 319, 311, 29, 305, 335, 275,
>> - 318, 321, 306, 323, 35, 35, 35, 35, 330, 329,
>> -
>> - 35, 35, 331, 333, 327, 35, 35, 338, 35, 35,
>> - 353, 340, 35, 35, 350, 325, 275, 315, 35, 35,
>> - 27, 27, 27, 27, 29, 29, 29, 31, 31, 31,
>> - 31, 36, 36, 36, 36, 62, 313, 62, 62, 63,
>> - 63, 63, 63, 65, 269, 65, 65, 35, 35, 35,
>> - 35, 69, 69, 261, 69, 94, 94, 94, 94, 96,
>> - 251, 96, 96, 128, 128, 128, 128, 143, 143, 143,
>> - 143, 149, 149, 149, 149, 153, 153, 153, 153, 158,
>> - 158, 158, 158, 165, 165, 165, 165, 167, 298, 167,
>> - 167, 180, 180, 180, 180, 185, 185, 185, 185, 187,
>> -
>> - 292, 187, 187, 192, 192, 192, 192, 194, 240, 194,
>> - 194, 197, 197, 197, 197, 199, 289, 199, 199, 203,
>> - 203, 203, 203, 205, 284, 205, 205, 210, 210, 210,
>> - 210, 169, 280, 169, 169, 221, 221, 221, 221, 223,
>> - 269, 223, 223, 230, 230, 230, 230, 189, 266, 189,
>> - 189, 196, 211, 196, 196, 201, 261, 201, 201, 207,
>> - 251, 207, 207, 237, 237, 237, 237, 239, 239, 239,
>> - 239, 225, 240, 225, 225, 250, 250, 250, 250, 253,
>> - 253, 253, 253, 255, 238, 255, 255, 260, 260, 260,
>> - 260, 263, 263, 263, 263, 265, 265, 265, 265, 268,
>> -
>> - 268, 268, 268, 274, 274, 274, 274, 279, 279, 279,
>> - 279, 257, 211, 257, 257, 283, 283, 283, 283, 287,
>> - 287, 287, 287, 264, 138, 264, 264, 291, 291, 291,
>> - 291, 297, 297, 297, 297, 304, 304, 304, 304, 306,
>> - 136, 306, 306, 312, 312, 312, 312, 314, 314, 314,
>> - 314, 308, 97, 308, 308, 324, 324, 324, 324, 326,
>> - 326, 326, 326, 332, 332, 332, 332, 334, 334, 334,
>> - 334, 336, 336, 336, 336, 341, 341, 341, 341, 343,
>> - 343, 343, 343, 345, 345, 345, 345, 347, 347, 347,
>> - 347, 351, 351, 351, 351, 36, 30, 59, 57, 36,
>> -
>> - 30, 354, 28, 28, 5, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354
>> + 36, 56, 58, 36, 36, 55, 83, 61, 51, 36,
>> + 54, 62, 52, 29, 65, 59, 32, 32, 33, 66,
>> +
>> + 36, 36, 71, 34, 29, 29, 29, 30, 36, 36,
>> + 77, 29, 38, 67, 67, 67, 68, 67, 75, 72,
>> + 67, 69, 73, 36, 36, 74, 78, 79, 36, 53,
>> + 36, 36, 36, 87, 36, 76, 84, 36, 36, 85,
>> + 36, 81, 36, 86, 36, 36, 36, 36, 82, 36,
>> + 92, 95, 36, 100, 36, 36, 89, 90, 88, 29,
>> + 65, 36, 91, 101, 36, 66, 90, 93, 36, 94,
>> + 29, 97, 102, 36, 36, 104, 98, 36, 103, 36,
>> + 36, 107, 108, 106, 36, 36, 36, 105, 86, 36,
>> + 109, 110, 111, 36, 36, 114, 112, 36, 117, 119,
>> +
>> + 36, 36, 36, 36, 36, 121, 36, 368, 36, 36,
>> + 120, 113, 29, 29, 29, 30, 118, 36, 134, 29,
>> + 38, 36, 127, 115, 116, 122, 123, 125, 36, 126,
>> + 128, 124, 29, 97, 36, 36, 180, 138, 98, 129,
>> + 129, 67, 130, 129, 36, 36, 129, 132, 133, 135,
>> + 136, 140, 36, 36, 36, 36, 142, 36, 137, 35,
>> + 35, 123, 86, 36, 370, 143, 144, 144, 67, 145,
>> + 144, 148, 158, 144, 147, 35, 35, 90, 119, 36,
>> + 36, 149, 150, 150, 67, 151, 150, 159, 36, 150,
>> + 153, 154, 154, 67, 155, 154, 164, 36, 154, 157,
>> +
>> + 160, 160, 67, 161, 160, 36, 368, 160, 163, 165,
>> + 166, 36, 36, 29, 170, 167, 168, 29, 172, 171,
>> + 36, 175, 36, 173, 35, 35, 176, 36, 36, 177,
>> + 36, 36, 188, 174, 36, 29, 190, 178, 36, 181,
>> + 36, 191, 223, 179, 182, 182, 67, 183, 182, 186,
>> + 206, 182, 185, 187, 29, 192, 35, 35, 35, 35,
>> + 193, 29, 197, 29, 199, 194, 36, 198, 36, 200,
>> + 29, 202, 29, 204, 195, 36, 203, 36, 205, 268,
>> + 207, 29, 209, 29, 211, 214, 213, 210, 218, 212,
>> + 217, 36, 353, 36, 29, 170, 36, 35, 35, 219,
>> +
>> + 171, 35, 35, 35, 35, 224, 36, 231, 36, 225,
>> + 36, 29, 227, 221, 36, 222, 232, 228, 220, 29,
>> + 229, 36, 240, 35, 35, 230, 233, 233, 67, 234,
>> + 233, 29, 190, 233, 236, 237, 348, 191, 238, 35,
>> + 29, 197, 29, 202, 239, 36, 198, 36, 203, 29,
>> + 209, 242, 36, 35, 247, 210, 255, 241, 248, 36,
>> + 35, 35, 36, 35, 35, 35, 35, 253, 36, 35,
>> + 35, 29, 227, 250, 269, 254, 36, 228, 249, 251,
>> + 252, 35, 258, 29, 260, 29, 262, 264, 36, 261,
>> + 265, 263, 35, 35, 346, 35, 35, 70, 271, 35,
>> +
>> + 35, 35, 35, 35, 35, 274, 35, 35, 282, 35,
>> + 35, 36, 277, 278, 35, 35, 283, 284, 35, 35,
>> + 279, 285, 36, 280, 288, 29, 260, 35, 35, 289,
>> + 312, 261, 293, 293, 67, 294, 293, 301, 306, 293,
>> + 296, 35, 35, 298, 303, 306, 304, 35, 35, 35,
>> + 35, 309, 308, 36, 307, 282, 302, 319, 35, 35,
>> + 35, 35, 35, 311, 29, 314, 29, 316, 35, 35,
>> + 315, 282, 317, 35, 35, 344, 310, 364, 325, 35,
>> + 35, 318, 35, 35, 329, 320, 36, 328, 332, 36,
>> + 29, 314, 35, 35, 330, 326, 315, 331, 327, 333,
>> +
>> + 35, 35, 35, 35, 282, 282, 340, 341, 35, 35,
>> + 35, 35, 36, 282, 35, 35, 36, 351, 35, 35,
>> + 362, 339, 365, 36, 338, 366, 342, 361, 360, 354,
>> + 358, 349, 356, 35, 35, 27, 27, 27, 27, 29,
>> + 29, 29, 31, 31, 31, 31, 36, 36, 36, 36,
>> + 63, 353, 63, 63, 64, 64, 64, 64, 66, 350,
>> + 66, 66, 35, 35, 35, 35, 70, 70, 324, 70,
>> + 96, 96, 96, 96, 98, 322, 98, 98, 131, 131,
>> + 131, 131, 146, 146, 146, 146, 152, 152, 152, 152,
>> + 156, 156, 156, 156, 162, 162, 162, 162, 169, 169,
>> +
>> + 169, 169, 171, 348, 171, 171, 184, 184, 184, 184,
>> + 189, 189, 189, 189, 191, 346, 191, 191, 196, 196,
>> + 196, 196, 198, 344, 198, 198, 201, 201, 201, 201,
>> + 203, 337, 203, 203, 208, 208, 208, 208, 210, 335,
>> + 210, 210, 215, 215, 215, 215, 173, 282, 173, 173,
>> + 226, 226, 226, 226, 228, 324, 228, 228, 235, 235,
>> + 235, 235, 193, 322, 193, 193, 200, 276, 200, 200,
>> + 205, 267, 205, 205, 212, 257, 212, 212, 243, 243,
>> + 243, 243, 245, 245, 245, 245, 230, 306, 230, 230,
>> + 256, 256, 256, 256, 259, 259, 259, 259, 261, 300,
>> +
>> + 261, 261, 266, 266, 266, 266, 270, 270, 270, 270,
>> + 272, 272, 272, 272, 275, 275, 275, 275, 281, 281,
>> + 281, 281, 286, 286, 286, 286, 263, 246, 263, 263,
>> + 290, 290, 290, 290, 295, 295, 295, 295, 271, 297,
>> + 271, 271, 299, 299, 299, 299, 305, 305, 305, 305,
>> + 313, 313, 313, 313, 315, 292, 315, 315, 321, 321,
>> + 321, 321, 323, 323, 323, 323, 317, 291, 317, 317,
>> + 334, 334, 334, 334, 336, 336, 336, 336, 343, 343,
>> + 343, 343, 345, 345, 345, 345, 347, 347, 347, 347,
>> + 352, 352, 352, 352, 355, 355, 355, 355, 357, 357,
>> +
>> + 357, 357, 359, 359, 359, 359, 363, 363, 363, 363,
>> + 367, 367, 367, 367, 369, 369, 369, 369, 287, 276,
>> + 273, 216, 267, 257, 246, 244, 216, 141, 139, 99,
>> + 36, 30, 60, 57, 36, 30, 371, 28, 28, 5,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371
>> } ;
>>
>> -static const flex_int16_t yy_chk[940] =
>> +static const flex_int16_t yy_chk[975] =
>> { 0,
>> 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
>> 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
>> @@ -927,101 +940,105 @@ static const flex_int16_t yy_chk[940] =
>> 18, 14, 11, 11, 13, 14, 11, 46, 46, 14,
>> 15, 16, 11, 12, 12, 12, 12, 12, 14, 16,
>> 12, 12, 12, 15, 19, 16, 20, 20, 21, 22,
>> - 24, 22, 24, 50, 26, 21, 50, 26, 19, 351,
>> - 20, 26, 19, 31, 31, 32, 32, 32, 39, 31,
>> -
>> - 39, 42, 32, 35, 35, 35, 35, 40, 44, 45,
>> - 35, 35, 37, 37, 37, 37, 37, 39, 42, 37,
>> - 37, 40, 41, 43, 41, 48, 45, 45, 49, 44,
>> - 47, 47, 53, 51, 43, 53, 48, 51, 52, 54,
>> - 52, 55, 56, 58, 54, 49, 57, 59, 60, 73,
>> - 61, 70, 60, 61, 347, 70, 56, 63, 63, 73,
>> - 58, 71, 59, 63, 59, 55, 66, 66, 57, 71,
>> - 74, 72, 66, 72, 75, 76, 77, 78, 79, 78,
>> - 77, 79, 80, 81, 74, 83, 80, 82, 75, 84,
>> - 82, 85, 88, 85, 76, 81, 87, 83, 87, 89,
>> -
>> - 92, 89, 93, 345, 90, 104, 92, 84, 86, 86,
>> - 86, 86, 90, 99, 88, 86, 86, 98, 102, 86,
>> - 86, 91, 91, 93, 91, 94, 94, 91, 101, 104,
>> - 102, 94, 101, 110, 99, 98, 100, 100, 100, 100,
>> - 100, 103, 103, 100, 100, 343, 105, 103, 105, 107,
>> - 109, 107, 111, 110, 109, 113, 113, 341, 121, 118,
>> - 111, 112, 112, 112, 112, 112, 121, 113, 112, 112,
>> - 114, 114, 116, 116, 118, 116, 114, 115, 115, 115,
>> - 115, 115, 123, 123, 115, 115, 117, 117, 117, 117,
>> - 117, 124, 122, 117, 117, 119, 122, 119, 120, 120,
>> -
>> - 120, 120, 120, 125, 130, 120, 120, 125, 131, 124,
>> - 126, 126, 128, 128, 131, 134, 126, 130, 128, 133,
>> - 133, 133, 135, 136, 133, 139, 164, 140, 138, 140,
>> - 134, 164, 133, 141, 141, 163, 163, 338, 139, 141,
>> - 136, 135, 137, 137, 137, 137, 137, 138, 336, 137,
>> - 137, 143, 143, 145, 145, 146, 146, 143, 147, 147,
>> - 149, 149, 145, 155, 147, 161, 149, 151, 151, 153,
>> - 153, 146, 160, 151, 270, 153, 176, 156, 156, 158,
>> - 158, 176, 155, 156, 161, 158, 165, 165, 170, 270,
>> - 160, 170, 165, 172, 172, 173, 173, 174, 174, 175,
>> -
>> - 208, 177, 220, 175, 177, 178, 178, 173, 220, 174,
>> - 208, 178, 180, 180, 172, 182, 182, 183, 180, 334,
>> - 190, 190, 183, 184, 184, 184, 184, 184, 185, 185,
>> - 184, 184, 190, 243, 185, 191, 191, 192, 192, 197,
>> - 197, 202, 202, 192, 332, 197, 203, 203, 209, 209,
>> - 213, 213, 203, 214, 214, 215, 215, 243, 216, 216,
>> - 217, 217, 218, 218, 219, 219, 221, 221, 215, 235,
>> - 219, 235, 221, 214, 216, 217, 227, 227, 228, 228,
>> - 230, 230, 232, 331, 228, 233, 230, 233, 233, 329,
>> - 232, 232, 236, 236, 241, 241, 244, 244, 245, 245,
>> -
>> - 241, 246, 246, 247, 248, 248, 267, 267, 244, 259,
>> - 259, 247, 247, 252, 252, 245, 248, 326, 246, 252,
>> - 253, 253, 267, 324, 259, 316, 253, 262, 262, 262,
>> - 262, 262, 271, 271, 262, 262, 272, 276, 273, 272,
>> - 272, 273, 273, 277, 278, 316, 276, 271, 281, 281,
>> - 299, 278, 278, 282, 282, 285, 285, 277, 300, 287,
>> - 287, 285, 290, 290, 281, 287, 323, 293, 294, 294,
>> - 290, 293, 303, 299, 301, 301, 302, 302, 310, 310,
>> - 303, 303, 300, 317, 302, 294, 304, 304, 322, 328,
>> - 301, 309, 304, 311, 309, 309, 311, 311, 318, 317,
>> -
>> - 318, 318, 319, 321, 314, 319, 319, 328, 330, 330,
>> - 350, 330, 340, 340, 340, 312, 297, 296, 350, 350,
>> - 355, 355, 355, 355, 356, 356, 356, 357, 357, 357,
>> - 357, 358, 358, 358, 358, 359, 295, 359, 359, 360,
>> - 360, 360, 360, 361, 291, 361, 361, 362, 362, 362,
>> - 362, 363, 363, 283, 363, 364, 364, 364, 364, 365,
>> - 279, 365, 365, 366, 366, 366, 366, 367, 367, 367,
>> - 367, 368, 368, 368, 368, 369, 369, 369, 369, 370,
>> - 370, 370, 370, 371, 371, 371, 371, 372, 274, 372,
>> - 372, 373, 373, 373, 373, 374, 374, 374, 374, 375,
>> -
>> - 268, 375, 375, 376, 376, 376, 376, 377, 265, 377,
>> - 377, 378, 378, 378, 378, 379, 263, 379, 379, 380,
>> - 380, 380, 380, 381, 260, 381, 381, 382, 382, 382,
>> - 382, 383, 250, 383, 383, 384, 384, 384, 384, 385,
>> - 242, 385, 385, 386, 386, 386, 386, 387, 239, 387,
>> - 387, 388, 237, 388, 388, 389, 234, 389, 389, 390,
>> - 226, 390, 390, 391, 391, 391, 391, 392, 392, 392,
>> - 392, 393, 212, 393, 393, 394, 394, 394, 394, 395,
>> - 395, 395, 395, 396, 210, 396, 396, 397, 397, 397,
>> - 397, 398, 398, 398, 398, 399, 399, 399, 399, 400,
>> -
>> - 400, 400, 400, 401, 401, 401, 401, 402, 402, 402,
>> - 402, 403, 162, 403, 403, 404, 404, 404, 404, 405,
>> - 405, 405, 405, 406, 108, 406, 406, 407, 407, 407,
>> - 407, 408, 408, 408, 408, 409, 409, 409, 409, 410,
>> - 106, 410, 410, 411, 411, 411, 411, 412, 412, 412,
>> - 412, 413, 69, 413, 413, 414, 414, 414, 414, 415,
>> - 415, 415, 415, 416, 416, 416, 416, 417, 417, 417,
>> - 417, 418, 418, 418, 418, 419, 419, 419, 419, 420,
>> - 420, 420, 420, 421, 421, 421, 421, 422, 422, 422,
>> - 422, 423, 423, 423, 423, 36, 29, 25, 23, 17,
>> -
>> - 6, 5, 4, 3, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354, 354,
>> - 354, 354, 354, 354, 354, 354, 354, 354, 354
>> + 24, 22, 24, 50, 26, 21, 50, 26, 19, 44,
>> + 20, 26, 19, 31, 31, 24, 32, 32, 32, 31,
>> +
>> + 39, 42, 39, 32, 35, 35, 35, 35, 40, 45,
>> + 44, 35, 35, 37, 37, 37, 37, 37, 42, 39,
>> + 37, 37, 40, 41, 43, 41, 45, 45, 47, 47,
>> + 48, 49, 51, 54, 55, 43, 51, 52, 54, 52,
>> + 53, 48, 56, 53, 57, 58, 59, 61, 49, 71,
>> + 59, 61, 60, 71, 62, 72, 56, 62, 55, 64,
>> + 64, 75, 58, 72, 77, 64, 57, 60, 74, 60,
>> + 67, 67, 73, 76, 73, 75, 67, 78, 74, 82,
>> + 79, 78, 79, 77, 84, 80, 81, 76, 80, 83,
>> + 81, 82, 83, 85, 89, 86, 84, 86, 88, 90,
>> +
>> + 88, 90, 91, 92, 100, 92, 104, 369, 95, 101,
>> + 91, 85, 87, 87, 87, 87, 89, 138, 104, 87,
>> + 87, 94, 100, 87, 87, 93, 93, 94, 93, 95,
>> + 101, 93, 96, 96, 106, 107, 138, 107, 96, 102,
>> + 102, 102, 102, 102, 103, 112, 102, 102, 103, 105,
>> + 105, 109, 111, 109, 113, 105, 111, 120, 106, 115,
>> + 115, 122, 113, 122, 367, 112, 114, 114, 114, 114,
>> + 114, 115, 120, 114, 114, 116, 116, 118, 118, 121,
>> + 118, 116, 117, 117, 117, 117, 117, 121, 124, 117,
>> + 117, 119, 119, 119, 119, 119, 124, 127, 119, 119,
>> +
>> + 123, 123, 123, 123, 123, 125, 365, 123, 123, 125,
>> + 126, 126, 128, 129, 129, 127, 128, 131, 131, 129,
>> + 133, 134, 139, 131, 136, 136, 136, 134, 137, 136,
>> + 141, 158, 143, 133, 143, 144, 144, 136, 179, 139,
>> + 142, 144, 179, 137, 140, 140, 140, 140, 140, 141,
>> + 158, 140, 140, 142, 146, 146, 148, 148, 149, 149,
>> + 146, 150, 150, 152, 152, 148, 165, 150, 164, 152,
>> + 154, 154, 156, 156, 149, 159, 154, 240, 156, 240,
>> + 159, 160, 160, 162, 162, 165, 164, 160, 168, 162,
>> + 167, 167, 363, 168, 169, 169, 174, 176, 176, 174,
>> +
>> + 169, 177, 177, 178, 178, 180, 181, 186, 186, 181,
>> + 180, 182, 182, 177, 207, 178, 187, 182, 176, 184,
>> + 184, 187, 207, 194, 194, 184, 188, 188, 188, 188,
>> + 188, 189, 189, 188, 188, 194, 359, 189, 195, 195,
>> + 196, 196, 201, 201, 206, 206, 196, 213, 201, 208,
>> + 208, 214, 214, 218, 218, 208, 225, 213, 219, 219,
>> + 220, 220, 225, 221, 221, 222, 222, 223, 223, 224,
>> + 224, 226, 226, 220, 241, 224, 241, 226, 219, 221,
>> + 222, 232, 232, 233, 233, 235, 235, 237, 249, 233,
>> + 238, 235, 238, 238, 357, 237, 237, 242, 242, 247,
>> +
>> + 247, 250, 250, 251, 251, 247, 252, 252, 253, 254,
>> + 254, 292, 249, 250, 265, 265, 253, 253, 258, 258,
>> + 251, 254, 277, 252, 258, 259, 259, 274, 274, 265,
>> + 292, 259, 269, 269, 269, 269, 269, 277, 284, 269,
>> + 269, 278, 278, 274, 279, 283, 280, 279, 279, 280,
>> + 280, 285, 284, 301, 283, 307, 278, 301, 285, 285,
>> + 288, 288, 289, 289, 293, 293, 295, 295, 302, 302,
>> + 293, 308, 295, 298, 298, 355, 288, 352, 307, 310,
>> + 310, 298, 309, 309, 311, 302, 312, 310, 319, 319,
>> + 313, 313, 311, 311, 312, 308, 313, 318, 309, 320,
>> +
>> + 318, 318, 320, 320, 325, 326, 327, 328, 327, 327,
>> + 328, 328, 330, 338, 340, 340, 342, 340, 351, 351,
>> + 351, 326, 354, 354, 325, 362, 330, 349, 347, 342,
>> + 345, 338, 343, 362, 362, 372, 372, 372, 372, 373,
>> + 373, 373, 374, 374, 374, 374, 375, 375, 375, 375,
>> + 376, 341, 376, 376, 377, 377, 377, 377, 378, 339,
>> + 378, 378, 379, 379, 379, 379, 380, 380, 336, 380,
>> + 381, 381, 381, 381, 382, 334, 382, 382, 383, 383,
>> + 383, 383, 384, 384, 384, 384, 385, 385, 385, 385,
>> + 386, 386, 386, 386, 387, 387, 387, 387, 388, 388,
>> +
>> + 388, 388, 389, 333, 389, 389, 390, 390, 390, 390,
>> + 391, 391, 391, 391, 392, 332, 392, 392, 393, 393,
>> + 393, 393, 394, 331, 394, 394, 395, 395, 395, 395,
>> + 396, 323, 396, 396, 397, 397, 397, 397, 398, 321,
>> + 398, 398, 399, 399, 399, 399, 400, 305, 400, 400,
>> + 401, 401, 401, 401, 402, 304, 402, 402, 403, 403,
>> + 403, 403, 404, 303, 404, 404, 405, 299, 405, 405,
>> + 406, 290, 406, 406, 407, 286, 407, 407, 408, 408,
>> + 408, 408, 409, 409, 409, 409, 410, 281, 410, 410,
>> + 411, 411, 411, 411, 412, 412, 412, 412, 413, 275,
>> +
>> + 413, 413, 414, 414, 414, 414, 415, 415, 415, 415,
>> + 416, 416, 416, 416, 417, 417, 417, 417, 418, 418,
>> + 418, 418, 419, 419, 419, 419, 420, 272, 420, 420,
>> + 421, 421, 421, 421, 422, 422, 422, 422, 423, 270,
>> + 423, 423, 424, 424, 424, 424, 425, 425, 425, 425,
>> + 426, 426, 426, 426, 427, 268, 427, 427, 428, 428,
>> + 428, 428, 429, 429, 429, 429, 430, 266, 430, 430,
>> + 431, 431, 431, 431, 432, 432, 432, 432, 433, 433,
>> + 433, 433, 434, 434, 434, 434, 435, 435, 435, 435,
>> + 436, 436, 436, 436, 437, 437, 437, 437, 438, 438,
>> +
>> + 438, 438, 439, 439, 439, 439, 440, 440, 440, 440,
>> + 441, 441, 441, 441, 442, 442, 442, 442, 256, 248,
>> + 245, 243, 239, 231, 217, 215, 166, 110, 108, 70,
>> + 36, 29, 25, 23, 17, 6, 5, 4, 3, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371, 371, 371, 371, 371, 371, 371,
>> + 371, 371, 371, 371
>> } ;
>>
>> #define YY_TRAILING_MASK 0x2000
>> @@ -1160,9 +1177,17 @@ static void setbackendtype(DiskParseContext
>> *dpc, const char *str) {
>> if ( !strcmp(str,"phy")) DSET(dpc,backend,BACKEND,str,PHY);
>> else if (!strcmp(str,"tap")) DSET(dpc,backend,BACKEND,str,TAP);
>> else if (!strcmp(str,"qdisk")) DSET(dpc,backend,BACKEND,str,QDISK);
>> + else if (!strcmp(str,"standalone"))
>> DSET(dpc,backend,BACKEND,str,STANDALONE);
>> else xlu__disk_err(dpc,str,"unknown value for backendtype");
>> }
>>
>> +/* Sets ->specification from the string. IDL should provide something for
>> this. */
>> +static void setspecification(DiskParseContext *dpc, const char *str) {
>> + if (!strcmp(str,"xen"))
>> DSET(dpc,specification,SPECIFICATION,str,XEN);
>> + else if (!strcmp(str,"virtio"))
>> DSET(dpc,specification,SPECIFICATION,str,VIRTIO);
>> + else xlu__disk_err(dpc,str,"unknown value for specification");
>> +}
>> +
>> /* Sets ->colo-port from the string. COLO need this. */
>> static void setcoloport(DiskParseContext *dpc, const char *str) {
>> int port = atoi(str);
>> @@ -1199,9 +1224,9 @@ static int vdev_and_devtype(DiskParseContext
>> *dpc, char *str) {
>> #undef DPC /* needs to be defined differently the actual lexer */
>> #define DPC ((DiskParseContext*)yyextra)
>>
>> -#line 1202 "libxlu_disk_l.c"
>> +#line 1227 "libxlu_disk_l.c"
>>
>> -#line 1204 "libxlu_disk_l.c"
>> +#line 1229 "libxlu_disk_l.c"
>>
>> #define INITIAL 0
>> #define LEXERR 1
>> @@ -1477,13 +1502,13 @@ YY_DECL
>> }
>>
>> {
>> -#line 177 "libxlu_disk_l.l"
>> +#line 185 "libxlu_disk_l.l"
>>
>>
>> -#line 180 "libxlu_disk_l.l"
>> +#line 188 "libxlu_disk_l.l"
>> /*----- the scanner rules which do the parsing -----*/
>>
>> -#line 1486 "libxlu_disk_l.c"
>> +#line 1511 "libxlu_disk_l.c"
>>
>> while ( /*CONSTCOND*/1 ) /* loops until end-of-file is
>> reached */
>> {
>> @@ -1515,14 +1540,14 @@ yy_match:
>> while ( yy_chk[yy_base[yy_current_state] + yy_c] !=
>> yy_current_state )
>> {
>> yy_current_state = (int)
>> yy_def[yy_current_state];
>> - if ( yy_current_state >= 355 )
>> + if ( yy_current_state >= 372 )
>> yy_c = yy_meta[yy_c];
>> }
>> yy_current_state = yy_nxt[yy_base[yy_current_state]
>> + yy_c];
>> *yyg->yy_state_ptr++ = yy_current_state;
>> ++yy_cp;
>> }
>> - while ( yy_current_state != 354 );
>> + while ( yy_current_state != 371 );
>>
>> yy_find_action:
>> yy_current_state = *--yyg->yy_state_ptr;
>> @@ -1572,152 +1597,158 @@ do_action: /* This label is used only to
>> access EOF actions. */
>> case 1:
>> /* rule 1 can match eol */
>> YY_RULE_SETUP
>> -#line 182 "libxlu_disk_l.l"
>> +#line 190 "libxlu_disk_l.l"
>> { /* ignore whitespace before parameters */ }
>> YY_BREAK
>> /* ordinary parameters setting enums or strings */
>> case 2:
>> /* rule 2 can match eol */
>> YY_RULE_SETUP
>> -#line 186 "libxlu_disk_l.l"
>> +#line 194 "libxlu_disk_l.l"
>> { STRIP(','); setformat(DPC, FROMEQUALS); }
>> YY_BREAK
>> case 3:
>> YY_RULE_SETUP
>> -#line 188 "libxlu_disk_l.l"
>> +#line 196 "libxlu_disk_l.l"
>> { DPC->disk->is_cdrom = 1; }
>> YY_BREAK
>> case 4:
>> YY_RULE_SETUP
>> -#line 189 "libxlu_disk_l.l"
>> +#line 197 "libxlu_disk_l.l"
>> { DPC->disk->is_cdrom = 1; }
>> YY_BREAK
>> case 5:
>> YY_RULE_SETUP
>> -#line 190 "libxlu_disk_l.l"
>> +#line 198 "libxlu_disk_l.l"
>> { DPC->disk->is_cdrom = 0; }
>> YY_BREAK
>> case 6:
>> /* rule 6 can match eol */
>> YY_RULE_SETUP
>> -#line 191 "libxlu_disk_l.l"
>> +#line 199 "libxlu_disk_l.l"
>> { xlu__disk_err(DPC,yytext,"unknown value for type"); }
>> YY_BREAK
>> case 7:
>> /* rule 7 can match eol */
>> YY_RULE_SETUP
>> -#line 193 "libxlu_disk_l.l"
>> +#line 201 "libxlu_disk_l.l"
>> { STRIP(','); setaccess(DPC, FROMEQUALS); }
>> YY_BREAK
>> case 8:
>> /* rule 8 can match eol */
>> YY_RULE_SETUP
>> -#line 194 "libxlu_disk_l.l"
>> +#line 202 "libxlu_disk_l.l"
>> { STRIP(','); SAVESTRING("backend", backend_domname, FROMEQUALS); }
>> YY_BREAK
>> case 9:
>> /* rule 9 can match eol */
>> YY_RULE_SETUP
>> -#line 195 "libxlu_disk_l.l"
>> +#line 203 "libxlu_disk_l.l"
>> { STRIP(','); setbackendtype(DPC,FROMEQUALS); }
>> YY_BREAK
>> case 10:
>> /* rule 10 can match eol */
>> YY_RULE_SETUP
>> -#line 197 "libxlu_disk_l.l"
>> -{ STRIP(','); SAVESTRING("vdev", vdev, FROMEQUALS); }
>> +#line 204 "libxlu_disk_l.l"
>> +{ STRIP(','); setspecification(DPC,FROMEQUALS); }
>> YY_BREAK
>> case 11:
>> /* rule 11 can match eol */
>> YY_RULE_SETUP
>> -#line 198 "libxlu_disk_l.l"
>> -{ STRIP(','); SAVESTRING("script", script, FROMEQUALS); }
>> +#line 206 "libxlu_disk_l.l"
>> +{ STRIP(','); SAVESTRING("vdev", vdev, FROMEQUALS); }
>> YY_BREAK
>> case 12:
>> +/* rule 12 can match eol */
>> YY_RULE_SETUP
>> -#line 199 "libxlu_disk_l.l"
>> -{ DPC->disk->direct_io_safe = 1; }
>> +#line 207 "libxlu_disk_l.l"
>> +{ STRIP(','); SAVESTRING("script", script, FROMEQUALS); }
>> YY_BREAK
>> case 13:
>> YY_RULE_SETUP
>> -#line 200 "libxlu_disk_l.l"
>> -{ libxl_defbool_set(&DPC->disk->discard_enable, true); }
>> +#line 208 "libxlu_disk_l.l"
>> +{ DPC->disk->direct_io_safe = 1; }
>> YY_BREAK
>> case 14:
>> YY_RULE_SETUP
>> -#line 201 "libxlu_disk_l.l"
>> -{ libxl_defbool_set(&DPC->disk->discard_enable, false); }
>> +#line 209 "libxlu_disk_l.l"
>> +{ libxl_defbool_set(&DPC->disk->discard_enable, true); }
>> YY_BREAK
>> -/* Note that the COLO configuration settings should be considered unstable.
>> - * They may change incompatibly in future versions of Xen. */
>> case 15:
>> YY_RULE_SETUP
>> -#line 204 "libxlu_disk_l.l"
>> -{ libxl_defbool_set(&DPC->disk->colo_enable, true); }
>> +#line 210 "libxlu_disk_l.l"
>> +{ libxl_defbool_set(&DPC->disk->discard_enable, false); }
>> YY_BREAK
>> +/* Note that the COLO configuration settings should be considered unstable.
>> + * They may change incompatibly in future versions of Xen. */
>> case 16:
>> YY_RULE_SETUP
>> -#line 205 "libxlu_disk_l.l"
>> -{ libxl_defbool_set(&DPC->disk->colo_enable, false); }
>> +#line 213 "libxlu_disk_l.l"
>> +{ libxl_defbool_set(&DPC->disk->colo_enable, true); }
>> YY_BREAK
>> case 17:
>> -/* rule 17 can match eol */
>> YY_RULE_SETUP
>> -#line 206 "libxlu_disk_l.l"
>> -{ STRIP(','); SAVESTRING("colo-host", colo_host, FROMEQUALS); }
>> +#line 214 "libxlu_disk_l.l"
>> +{ libxl_defbool_set(&DPC->disk->colo_enable, false); }
>> YY_BREAK
>> case 18:
>> /* rule 18 can match eol */
>> YY_RULE_SETUP
>> -#line 207 "libxlu_disk_l.l"
>> -{ STRIP(','); setcoloport(DPC, FROMEQUALS); }
>> +#line 215 "libxlu_disk_l.l"
>> +{ STRIP(','); SAVESTRING("colo-host", colo_host, FROMEQUALS); }
>> YY_BREAK
>> case 19:
>> /* rule 19 can match eol */
>> YY_RULE_SETUP
>> -#line 208 "libxlu_disk_l.l"
>> -{ STRIP(','); SAVESTRING("colo-export", colo_export, FROMEQUALS); }
>> +#line 216 "libxlu_disk_l.l"
>> +{ STRIP(','); setcoloport(DPC, FROMEQUALS); }
>> YY_BREAK
>> case 20:
>> /* rule 20 can match eol */
>> YY_RULE_SETUP
>> -#line 209 "libxlu_disk_l.l"
>> -{ STRIP(','); SAVESTRING("active-disk", active_disk, FROMEQUALS); }
>> +#line 217 "libxlu_disk_l.l"
>> +{ STRIP(','); SAVESTRING("colo-export", colo_export, FROMEQUALS); }
>> YY_BREAK
>> case 21:
>> /* rule 21 can match eol */
>> YY_RULE_SETUP
>> -#line 210 "libxlu_disk_l.l"
>> +#line 218 "libxlu_disk_l.l"
>> +{ STRIP(','); SAVESTRING("active-disk", active_disk, FROMEQUALS); }
>> + YY_BREAK
>> +case 22:
>> +/* rule 22 can match eol */
>> +YY_RULE_SETUP
>> +#line 219 "libxlu_disk_l.l"
>> { STRIP(','); SAVESTRING("hidden-disk", hidden_disk, FROMEQUALS); }
>> YY_BREAK
>> /* the target magic parameter, eats the rest of the string */
>> -case 22:
>> +case 23:
>> YY_RULE_SETUP
>> -#line 214 "libxlu_disk_l.l"
>> +#line 223 "libxlu_disk_l.l"
>> { STRIP(','); SAVESTRING("target", pdev_path, FROMEQUALS); }
>> YY_BREAK
>> /* unknown parameters */
>> -case 23:
>> -/* rule 23 can match eol */
>> +case 24:
>> +/* rule 24 can match eol */
>> YY_RULE_SETUP
>> -#line 218 "libxlu_disk_l.l"
>> +#line 227 "libxlu_disk_l.l"
>> { xlu__disk_err(DPC,yytext,"unknown parameter"); }
>> YY_BREAK
>> /* deprecated prefixes */
>> /* the "/.*" in these patterns ensures that they count as if they
>> * matched the whole string, so these patterns take precedence */
>> -case 24:
>> +case 25:
>> YY_RULE_SETUP
>> -#line 225 "libxlu_disk_l.l"
>> +#line 234 "libxlu_disk_l.l"
>> {
>> STRIP(':');
>> DPC->had_depr_prefix=1; DEPRECATE("use
>> `[format=]...,'");
>> setformat(DPC, yytext);
>> }
>> YY_BREAK
>> -case 25:
>> +case 26:
>> YY_RULE_SETUP
>> -#line 231 "libxlu_disk_l.l"
>> +#line 240 "libxlu_disk_l.l"
>> {
>> char *newscript;
>> STRIP(':');
>> @@ -1731,65 +1762,65 @@ YY_RULE_SETUP
>> free(newscript);
>> }
>> YY_BREAK
>> -case 26:
>> +case 27:
>> *yy_cp = yyg->yy_hold_char; /* undo effects of setting up yytext */
>> yyg->yy_c_buf_p = yy_cp = yy_bp + 8;
>> YY_DO_BEFORE_ACTION; /* set up yytext again */
>> YY_RULE_SETUP
>> -#line 244 "libxlu_disk_l.l"
>> +#line 253 "libxlu_disk_l.l"
>> { DPC->had_depr_prefix=1; DEPRECATE(0); }
>> YY_BREAK
>> -case 27:
>> +case 28:
>> YY_RULE_SETUP
>> -#line 245 "libxlu_disk_l.l"
>> +#line 254 "libxlu_disk_l.l"
>> { DPC->had_depr_prefix=1; DEPRECATE(0); }
>> YY_BREAK
>> -case 28:
>> +case 29:
>> *yy_cp = yyg->yy_hold_char; /* undo effects of setting up yytext */
>> yyg->yy_c_buf_p = yy_cp = yy_bp + 4;
>> YY_DO_BEFORE_ACTION; /* set up yytext again */
>> YY_RULE_SETUP
>> -#line 246 "libxlu_disk_l.l"
>> +#line 255 "libxlu_disk_l.l"
>> { DPC->had_depr_prefix=1; DEPRECATE(0); }
>> YY_BREAK
>> -case 29:
>> +case 30:
>> *yy_cp = yyg->yy_hold_char; /* undo effects of setting up yytext */
>> yyg->yy_c_buf_p = yy_cp = yy_bp + 6;
>> YY_DO_BEFORE_ACTION; /* set up yytext again */
>> YY_RULE_SETUP
>> -#line 247 "libxlu_disk_l.l"
>> +#line 256 "libxlu_disk_l.l"
>> { DPC->had_depr_prefix=1; DEPRECATE(0); }
>> YY_BREAK
>> -case 30:
>> +case 31:
>> *yy_cp = yyg->yy_hold_char; /* undo effects of setting up yytext */
>> yyg->yy_c_buf_p = yy_cp = yy_bp + 5;
>> YY_DO_BEFORE_ACTION; /* set up yytext again */
>> YY_RULE_SETUP
>> -#line 248 "libxlu_disk_l.l"
>> +#line 257 "libxlu_disk_l.l"
>> { DPC->had_depr_prefix=1; DEPRECATE(0); }
>> YY_BREAK
>> -case 31:
>> +case 32:
>> *yy_cp = yyg->yy_hold_char; /* undo effects of setting up yytext */
>> yyg->yy_c_buf_p = yy_cp = yy_bp + 4;
>> YY_DO_BEFORE_ACTION; /* set up yytext again */
>> YY_RULE_SETUP
>> -#line 249 "libxlu_disk_l.l"
>> +#line 258 "libxlu_disk_l.l"
>> { DPC->had_depr_prefix=1; DEPRECATE(0); }
>> YY_BREAK
>> -case 32:
>> -/* rule 32 can match eol */
>> +case 33:
>> +/* rule 33 can match eol */
>> YY_RULE_SETUP
>> -#line 251 "libxlu_disk_l.l"
>> +#line 260 "libxlu_disk_l.l"
>> {
>> xlu__disk_err(DPC,yytext,"unknown deprecated disk
>> prefix");
>> return 0;
>> }
>> YY_BREAK
>> /* positional parameters */
>> -case 33:
>> -/* rule 33 can match eol */
>> +case 34:
>> +/* rule 34 can match eol */
>> YY_RULE_SETUP
>> -#line 258 "libxlu_disk_l.l"
>> +#line 267 "libxlu_disk_l.l"
>> {
>> STRIP(',');
>>
>> @@ -1816,27 +1847,27 @@ YY_RULE_SETUP
>> }
>> }
>> YY_BREAK
>> -case 34:
>> +case 35:
>> YY_RULE_SETUP
>> -#line 284 "libxlu_disk_l.l"
>> +#line 293 "libxlu_disk_l.l"
>> {
>> BEGIN(LEXERR);
>> yymore();
>> }
>> YY_BREAK
>> -case 35:
>> +case 36:
>> YY_RULE_SETUP
>> -#line 288 "libxlu_disk_l.l"
>> +#line 297 "libxlu_disk_l.l"
>> {
>> xlu__disk_err(DPC,yytext,"bad disk syntax"); return 0;
>> }
>> YY_BREAK
>> -case 36:
>> +case 37:
>> YY_RULE_SETUP
>> -#line 291 "libxlu_disk_l.l"
>> +#line 300 "libxlu_disk_l.l"
>> YY_FATAL_ERROR( "flex scanner jammed" );
>> YY_BREAK
>> -#line 1839 "libxlu_disk_l.c"
>> +#line 1870 "libxlu_disk_l.c"
>> case YY_STATE_EOF(INITIAL):
>> case YY_STATE_EOF(LEXERR):
>> yyterminate();
>> @@ -2104,7 +2135,7 @@ static int yy_get_next_buffer (yyscan_t yyscanner)
>> while ( yy_chk[yy_base[yy_current_state] + yy_c] !=
>> yy_current_state )
>> {
>> yy_current_state = (int) yy_def[yy_current_state];
>> - if ( yy_current_state >= 355 )
>> + if ( yy_current_state >= 372 )
>> yy_c = yy_meta[yy_c];
>> }
>> yy_current_state = yy_nxt[yy_base[yy_current_state] + yy_c];
>> @@ -2128,11 +2159,11 @@ static int yy_get_next_buffer (yyscan_t
>> yyscanner)
>> while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
>> {
>> yy_current_state = (int) yy_def[yy_current_state];
>> - if ( yy_current_state >= 355 )
>> + if ( yy_current_state >= 372 )
>> yy_c = yy_meta[yy_c];
>> }
>> yy_current_state = yy_nxt[yy_base[yy_current_state] + yy_c];
>> - yy_is_jam = (yy_current_state == 354);
>> + yy_is_jam = (yy_current_state == 371);
>> if ( ! yy_is_jam )
>> *yyg->yy_state_ptr++ = yy_current_state;
>>
>> @@ -2941,4 +2972,4 @@ void yyfree (void * ptr , yyscan_t yyscanner)
>>
>> #define YYTABLES_NAME "yytables"
>>
>> -#line 291 "libxlu_disk_l.l"
>> +#line 300 "libxlu_disk_l.l"
>> diff --git a/tools/libs/util/libxlu_disk_l.h
>> b/tools/libs/util/libxlu_disk_l.h
>> index 6abeecf279..509aad67dc 100644
>> --- a/tools/libs/util/libxlu_disk_l.h
>> +++ b/tools/libs/util/libxlu_disk_l.h
>> @@ -694,7 +694,7 @@ extern int yylex (yyscan_t yyscanner);
>> #undef yyTABLES_NAME
>> #endif
>>
>> -#line 291 "libxlu_disk_l.l"
>> +#line 300 "libxlu_disk_l.l"
>>
>> #line 699 "libxlu_disk_l.h"
>> #undef xlu__disk_yyIN_HEADER
>> diff --git a/tools/libs/util/libxlu_disk_l.l
>> b/tools/libs/util/libxlu_disk_l.l
>> index e115460d99..6d53c093a3 100644
>> --- a/tools/libs/util/libxlu_disk_l.l
>> +++ b/tools/libs/util/libxlu_disk_l.l
>> @@ -122,9 +122,17 @@ static void setbackendtype(DiskParseContext *dpc,
>> const char *str) {
>> if ( !strcmp(str,"phy")) DSET(dpc,backend,BACKEND,str,PHY);
>> else if (!strcmp(str,"tap")) DSET(dpc,backend,BACKEND,str,TAP);
>> else if (!strcmp(str,"qdisk")) DSET(dpc,backend,BACKEND,str,QDISK);
>> + else if (!strcmp(str,"standalone"))
>> DSET(dpc,backend,BACKEND,str,STANDALONE);
>> else xlu__disk_err(dpc,str,"unknown value for backendtype");
>> }
>>
>> +/* Sets ->specification from the string. IDL should provide something for
>> this. */
>> +static void setspecification(DiskParseContext *dpc, const char *str) {
>> + if (!strcmp(str,"xen"))
>> DSET(dpc,specification,SPECIFICATION,str,XEN);
>> + else if (!strcmp(str,"virtio"))
>> DSET(dpc,specification,SPECIFICATION,str,VIRTIO);
>> + else xlu__disk_err(dpc,str,"unknown value for specification");
>> +}
>> +
>> /* Sets ->colo-port from the string. COLO need this. */
>> static void setcoloport(DiskParseContext *dpc, const char *str) {
>> int port = atoi(str);
>> @@ -192,6 +200,7 @@ devtype=[^,]*,?
>> { xlu__disk_err(DPC,yytext,"unknown value for type"); }
>> access=[^,]*,? { STRIP(','); setaccess(DPC, FROMEQUALS); }
>> backend=[^,]*,? { STRIP(','); SAVESTRING("backend", backend_domname,
>> FROMEQUALS); }
>> backendtype=[^,]*,? { STRIP(','); setbackendtype(DPC,FROMEQUALS); }
>> +specification=[^,]*,? { STRIP(','); setspecification(DPC,FROMEQUALS); }
>>
>> vdev=[^,]*,? { STRIP(','); SAVESTRING("vdev", vdev, FROMEQUALS); }
>> script=[^,]*,? { STRIP(','); SAVESTRING("script", script, FROMEQUALS);
>> }
>> diff --git a/tools/xl/xl_block.c b/tools/xl/xl_block.c
>> index 70eed431e4..8836c07d6b 100644
>> --- a/tools/xl/xl_block.c
>> +++ b/tools/xl/xl_block.c
>> @@ -119,6 +119,12 @@ int main_blockdetach(int argc, char **argv)
>> fprintf(stderr, "Error: Device %s not connected.\n",
>> argv[optind+1]);
>> return 1;
>> }
>> +
>> + if (disk.specification == LIBXL_DISK_SPECIFICATION_VIRTIO) {
>> + fprintf(stderr, "Hotunplug isn't supported for specification
>> virtio\n");
>> + return 1;
>> + }
>> +
>> rc = !force ? libxl_device_disk_safe_remove(ctx, domid, &disk, 0) :
>> libxl_device_disk_destroy(ctx, domid, &disk, 0);
>> if (rc) {
>> --
>> 2.25.1
>>
--
Regards,
Oleksandr Tyshchenko
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |