From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 78938C5DF62 for ; Wed, 6 Nov 2019 13:41:45 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 33DF82075C for ; Wed, 6 Nov 2019 13:41:45 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="chmMjimA" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731856AbfKFNlo (ORCPT ); Wed, 6 Nov 2019 08:41:44 -0500 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:58147 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731731AbfKFNll (ORCPT ); Wed, 6 Nov 2019 08:41:41 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1573047699; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JGqg8qP39vMXnP+EB/M2jo3uCi2AD9tZlxsLNrs4jIY=; b=chmMjimA8DDpv+n1Qg8fF4UN+M5kRSVz5yMaefLPbjSA9/J6Vhom4qlFuriCbZFJXPiIA8 cldunI9DVoHKioSruFi5EG1WIKs1ZlaLhtvtJHQuWoqO6tVPAc3Scd21p+K1JyzL7ROqTT nusDO0Tyc75ZaKjuXzMwCKjOdpV0qwU= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-37-ekA3G6WPOvC5qgCYmwwjcw-1; Wed, 06 Nov 2019 08:41:36 -0500 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id C23CB1800DFB; Wed, 6 Nov 2019 13:41:32 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-193.pek2.redhat.com [10.72.12.193]) by smtp.corp.redhat.com (Postfix) with ESMTP id 6C7B219756; Wed, 6 Nov 2019 13:41:04 +0000 (UTC) From: Jason Wang To: kvm@vger.kernel.org, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com, alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com Cc: virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, cohuck@redhat.com, maxime.coquelin@redhat.com, cunming.liang@intel.com, zhihong.wang@intel.com, rob.miller@broadcom.com, xiao.w.wang@intel.com, haotian.wang@sifive.com, zhenyuw@linux.intel.com, zhi.a.wang@intel.com, jani.nikula@linux.intel.com, joonas.lahtinen@linux.intel.com, rodrigo.vivi@intel.com, airlied@linux.ie, daniel@ffwll.ch, farman@linux.ibm.com, pasic@linux.ibm.com, sebott@linux.ibm.com, oberpar@linux.ibm.com, heiko.carstens@de.ibm.com, gor@linux.ibm.com, borntraeger@de.ibm.com, akrowiak@linux.ibm.com, freude@linux.ibm.com, lingshan.zhu@intel.com, idos@mellanox.com, eperezma@redhat.com, lulu@redhat.com, parav@mellanox.com, christophe.de.dinechin@gmail.com, kevin.tian@intel.com, stefanha@redhat.com, Jason Wang Subject: [PATCH V10 5/6] virtio: introduce a mdev based transport Date: Wed, 6 Nov 2019 21:35:30 +0800 Message-Id: <20191106133531.693-6-jasowang@redhat.com> In-Reply-To: <20191106133531.693-1-jasowang@redhat.com> References: <20191106133531.693-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 X-MC-Unique: ekA3G6WPOvC5qgCYmwwjcw-1 X-Mimecast-Spam-Score: 0 Content-Type: text/plain; charset=WINDOWS-1252 Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch introduces a new mdev transport for virtio. This is used to use kernel virtio driver to drive the mediated device that is capable of populating virtqueue directly. A new virtio-mdev driver will be registered to the mdev bus, when a new virtio-mdev device is probed, it will register the device with mdev based config ops. This means it is a software transport between mdev driver and mdev device. The transport was implemented through virtio device specific ops. Reviewed-by: Cornelia Huck Signed-off-by: Jason Wang --- drivers/virtio/Kconfig | 13 ++ drivers/virtio/Makefile | 1 + drivers/virtio/virtio_mdev.c | 406 +++++++++++++++++++++++++++++++++++ 3 files changed, 420 insertions(+) create mode 100644 drivers/virtio/virtio_mdev.c diff --git a/drivers/virtio/Kconfig b/drivers/virtio/Kconfig index 078615cf2afc..bf526ce0facc 100644 --- a/drivers/virtio/Kconfig +++ b/drivers/virtio/Kconfig @@ -43,6 +43,19 @@ config VIRTIO_PCI_LEGACY =20 =09 If unsure, say Y. =20 +config VIRTIO_MDEV +=09tristate "MDEV driver for virtio devices" +=09depends on VFIO_MDEV && VIRTIO +=09default n +=09help +=09 This driver provides support for virtio based paravirtual +=09 device driver over MDEV bus. For this to be useful, you need +=09 an appropriate virtio mdev device implementation that +=09 operates on a physical device to allow the datapath of virtio +=09 to be offloaded to hardware. + +=09 If unsure, say M. + config VIRTIO_PMEM =09tristate "Support for virtio pmem driver" =09depends on VIRTIO diff --git a/drivers/virtio/Makefile b/drivers/virtio/Makefile index 3a2b5c5dcf46..f2997b6c812f 100644 --- a/drivers/virtio/Makefile +++ b/drivers/virtio/Makefile @@ -6,3 +6,4 @@ virtio_pci-y :=3D virtio_pci_modern.o virtio_pci_common.o virtio_pci-$(CONFIG_VIRTIO_PCI_LEGACY) +=3D virtio_pci_legacy.o obj-$(CONFIG_VIRTIO_BALLOON) +=3D virtio_balloon.o obj-$(CONFIG_VIRTIO_INPUT) +=3D virtio_input.o +obj-$(CONFIG_VIRTIO_MDEV) +=3D virtio_mdev.o diff --git a/drivers/virtio/virtio_mdev.c b/drivers/virtio/virtio_mdev.c new file mode 100644 index 000000000000..9e12ef240493 --- /dev/null +++ b/drivers/virtio/virtio_mdev.c @@ -0,0 +1,406 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * VIRTIO based driver for Mediated device + * + * Copyright (c) 2019, Red Hat. All rights reserved. + * Author: Jason Wang + * + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#define DRIVER_VERSION "0.1" +#define DRIVER_AUTHOR "Red Hat Corporation" +#define DRIVER_DESC "VIRTIO based driver for Mediated device" + +#define to_virtio_mdev_device(dev) \ +=09container_of(dev, struct virtio_mdev_device, vdev) + +struct virtio_mdev_device { +=09struct virtio_device vdev; +=09struct mdev_device *mdev; +=09u64 features; + +=09/* The lock to protect virtqueue list */ +=09spinlock_t lock; +=09/* List of virtio_mdev_vq_info */ +=09struct list_head virtqueues; +}; + +struct virtio_mdev_vq_info { +=09/* the actual virtqueue */ +=09struct virtqueue *vq; + +=09/* the list node for the virtqueues list */ +=09struct list_head node; +}; + +static struct mdev_device *vm_get_mdev(struct virtio_device *vdev) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; + +=09return mdev; +} + +static void virtio_mdev_get(struct virtio_device *vdev, unsigned offset, +=09=09=09 void *buf, unsigned len) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09ops->get_config(mdev, offset, buf, len); +} + +static void virtio_mdev_set(struct virtio_device *vdev, unsigned offset, +=09=09=09 const void *buf, unsigned len) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09ops->set_config(mdev, offset, buf, len); +} + +static u32 virtio_mdev_generation(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09if (ops->get_generation) +=09=09return ops->get_generation(mdev); + +=09return 0; +} + +static u8 virtio_mdev_get_status(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->get_status(mdev); +} + +static void virtio_mdev_set_status(struct virtio_device *vdev, u8 status) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->set_status(mdev, status); +} + +static void virtio_mdev_reset(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->set_status(mdev, 0); +} + +static bool virtio_mdev_notify(struct virtqueue *vq) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vq->vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09ops->kick_vq(mdev, vq->index); + +=09return true; +} + +static irqreturn_t virtio_mdev_config_cb(void *private) +{ +=09struct virtio_mdev_device *vm_dev =3D private; + +=09virtio_config_changed(&vm_dev->vdev); + +=09return IRQ_HANDLED; +} + +static irqreturn_t virtio_mdev_virtqueue_cb(void *private) +{ +=09struct virtio_mdev_vq_info *info =3D private; + +=09return vring_interrupt(0, info->vq); +} + +static struct virtqueue * +virtio_mdev_setup_vq(struct virtio_device *vdev, unsigned int index, +=09=09 void (*callback)(struct virtqueue *vq), +=09=09 const char *name, bool ctx) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_vq_info *info; +=09struct virtio_mdev_callback cb; +=09struct virtqueue *vq; +=09u64 desc_addr, driver_addr, device_addr; +=09unsigned long flags; +=09u32 align, num; +=09int err; + +=09if (!name) +=09=09return NULL; + +=09/* Queue shouldn't already be set up. */ +=09if (ops->get_vq_ready(mdev, index)) +=09=09return ERR_PTR(-ENOENT); + +=09/* Allocate and fill out our active queue description */ +=09info =3D kmalloc(sizeof(*info), GFP_KERNEL); +=09if (!info) +=09=09return ERR_PTR(-ENOMEM); + +=09num =3D ops->get_vq_num_max(mdev); +=09if (num =3D=3D 0) { +=09=09err =3D -ENOENT; +=09=09goto error_new_virtqueue; +=09} + +=09/* Create the vring */ +=09align =3D ops->get_vq_align(mdev); +=09vq =3D vring_create_virtqueue(index, num, align, vdev, +=09=09=09=09 true, true, ctx, +=09=09=09=09 virtio_mdev_notify, callback, name); +=09if (!vq) { +=09=09err =3D -ENOMEM; +=09=09goto error_new_virtqueue; +=09} + +=09/* Setup virtqueue callback */ +=09cb.callback =3D virtio_mdev_virtqueue_cb; +=09cb.private =3D info; +=09ops->set_vq_cb(mdev, index, &cb); +=09ops->set_vq_num(mdev, index, virtqueue_get_vring_size(vq)); + +=09desc_addr =3D virtqueue_get_desc_addr(vq); +=09driver_addr =3D virtqueue_get_avail_addr(vq); +=09device_addr =3D virtqueue_get_used_addr(vq); + +=09if (ops->set_vq_address(mdev, index, +=09=09=09=09desc_addr, driver_addr, +=09=09=09=09device_addr)) { +=09=09err =3D -EINVAL; +=09=09goto err_vq; +=09} + +=09ops->set_vq_ready(mdev, index, 1); + +=09vq->priv =3D info; +=09info->vq =3D vq; + +=09spin_lock_irqsave(&vm_dev->lock, flags); +=09list_add(&info->node, &vm_dev->virtqueues); +=09spin_unlock_irqrestore(&vm_dev->lock, flags); + +=09return vq; + +err_vq: +=09vring_del_virtqueue(vq); +error_new_virtqueue: +=09ops->set_vq_ready(mdev, index, 0); +=09WARN_ON(ops->get_vq_ready(mdev, index)); +=09kfree(info); +=09return ERR_PTR(err); +} + +static void virtio_mdev_del_vq(struct virtqueue *vq) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vq->vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_vq_info *info =3D vq->priv; +=09unsigned int index =3D vq->index; +=09unsigned long flags; + +=09spin_lock_irqsave(&vm_dev->lock, flags); +=09list_del(&info->node); +=09spin_unlock_irqrestore(&vm_dev->lock, flags); + +=09/* Select and deactivate the queue */ +=09ops->set_vq_ready(mdev, index, 0); +=09WARN_ON(ops->get_vq_ready(mdev, index)); + +=09vring_del_virtqueue(vq); + +=09kfree(info); +} + +static void virtio_mdev_del_vqs(struct virtio_device *vdev) +{ +=09struct virtqueue *vq, *n; + +=09list_for_each_entry_safe(vq, n, &vdev->vqs, list) +=09=09virtio_mdev_del_vq(vq); +} + +static int virtio_mdev_find_vqs(struct virtio_device *vdev, unsigned nvqs, +=09=09=09=09struct virtqueue *vqs[], +=09=09=09=09vq_callback_t *callbacks[], +=09=09=09=09const char * const names[], +=09=09=09=09const bool *ctx, +=09=09=09=09struct irq_affinity *desc) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_callback cb; +=09int i, err, queue_idx =3D 0; + +=09for (i =3D 0; i < nvqs; ++i) { +=09=09if (!names[i]) { +=09=09=09vqs[i] =3D NULL; +=09=09=09continue; +=09=09} + +=09=09vqs[i] =3D virtio_mdev_setup_vq(vdev, queue_idx++, +=09=09=09=09=09 callbacks[i], names[i], ctx ? +=09=09=09=09=09 ctx[i] : false); +=09=09if (IS_ERR(vqs[i])) { +=09=09=09err =3D PTR_ERR(vqs[i]); +=09=09=09goto err_setup_vq; +=09=09} +=09} + +=09cb.callback =3D virtio_mdev_config_cb; +=09cb.private =3D vm_dev; +=09ops->set_config_cb(mdev, &cb); + +=09return 0; + +err_setup_vq: +=09virtio_mdev_del_vqs(vdev); +=09return err; +} + +static u64 virtio_mdev_get_features(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->get_features(mdev); +} + +static int virtio_mdev_finalize_features(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09/* Give virtio_ring a chance to accept features. */ +=09vring_transport_features(vdev); + +=09return ops->set_features(mdev, vdev->features); +} + +static const char *virtio_mdev_bus_name(struct virtio_device *vdev) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; + +=09return dev_name(mdev_dev(mdev)); +} + +static const struct virtio_config_ops virtio_mdev_config_ops =3D { +=09.get=09=09=3D virtio_mdev_get, +=09.set=09=09=3D virtio_mdev_set, +=09.generation=09=3D virtio_mdev_generation, +=09.get_status=09=3D virtio_mdev_get_status, +=09.set_status=09=3D virtio_mdev_set_status, +=09.reset=09=09=3D virtio_mdev_reset, +=09.find_vqs=09=3D virtio_mdev_find_vqs, +=09.del_vqs=09=3D virtio_mdev_del_vqs, +=09.get_features=09=3D virtio_mdev_get_features, +=09.finalize_features =3D virtio_mdev_finalize_features, +=09.bus_name=09=3D virtio_mdev_bus_name, +}; + +static void virtio_mdev_release_dev(struct device *_d) +{ +=09struct virtio_device *vdev =3D +=09 container_of(_d, struct virtio_device, dev); +=09struct virtio_mdev_device *vm_dev =3D +=09 container_of(vdev, struct virtio_mdev_device, vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; + +=09devm_kfree(mdev_dev(mdev), vm_dev); +} + +static int virtio_mdev_probe(struct device *dev) +{ +=09struct mdev_device *mdev =3D mdev_from_dev(dev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_device *vm_dev; +=09int rc; + +=09vm_dev =3D devm_kzalloc(dev, sizeof(*vm_dev), GFP_KERNEL); +=09if (!vm_dev) +=09=09return -ENOMEM; + +=09vm_dev->vdev.dev.parent =3D dev; +=09vm_dev->vdev.dev.release =3D virtio_mdev_release_dev; +=09vm_dev->vdev.config =3D &virtio_mdev_config_ops; +=09vm_dev->mdev =3D mdev; +=09INIT_LIST_HEAD(&vm_dev->virtqueues); +=09spin_lock_init(&vm_dev->lock); + +=09vm_dev->vdev.id.device =3D ops->get_device_id(mdev); +=09if (vm_dev->vdev.id.device =3D=3D 0) +=09=09return -ENODEV; + +=09vm_dev->vdev.id.vendor =3D ops->get_vendor_id(mdev); +=09rc =3D register_virtio_device(&vm_dev->vdev); +=09if (rc) +=09=09put_device(dev); +=09else +=09=09dev_set_drvdata(dev, vm_dev); + +=09return rc; +} + +static void virtio_mdev_remove(struct device *dev) +{ +=09struct virtio_mdev_device *vm_dev =3D dev_get_drvdata(dev); + +=09unregister_virtio_device(&vm_dev->vdev); +} + +static const struct mdev_class_id virtio_id_table[] =3D { +=09{ MDEV_CLASS_ID_VIRTIO }, +=09{ 0 }, +}; + +MODULE_DEVICE_TABLE(mdev, virtio_id_table); + +static struct mdev_driver virtio_mdev_driver =3D { +=09.name=09=3D "virtio_mdev", +=09.probe=09=3D virtio_mdev_probe, +=09.remove =3D virtio_mdev_remove, +=09.id_table =3D virtio_id_table, +}; + +static int __init virtio_mdev_init(void) +{ +=09return mdev_register_driver(&virtio_mdev_driver, THIS_MODULE); +} + +static void __exit virtio_mdev_exit(void) +{ +=09mdev_unregister_driver(&virtio_mdev_driver); +} + +module_init(virtio_mdev_init) +module_exit(virtio_mdev_exit) + +MODULE_VERSION(DRIVER_VERSION); +MODULE_LICENSE("GPL v2"); +MODULE_AUTHOR(DRIVER_AUTHOR); +MODULE_DESCRIPTION(DRIVER_DESC); --=20 2.19.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jason Wang Subject: [PATCH V10 5/6] virtio: introduce a mdev based transport Date: Wed, 6 Nov 2019 21:35:30 +0800 Message-ID: <20191106133531.693-6-jasowang@redhat.com> References: <20191106133531.693-1-jasowang@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=WINDOWS-1252 Content-Transfer-Encoding: quoted-printable Return-path: In-Reply-To: <20191106133531.693-1-jasowang@redhat.com> Sender: netdev-owner@vger.kernel.org To: kvm@vger.kernel.org, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com, alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com Cc: virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, cohuck@redhat.com, maxime.coquelin@redhat.com, cunming.liang@intel.com, zhihong.wang@intel.com, rob.miller@broadcom.com, xiao.w.wang@intel.com, haotian.wang@sifive.com, zhenyuw@linux.intel.com, zhi.a.wang@intel.com, jani.nikula@linux.intel.com, joonas.lahtinen@linux.intel.com, rodrigo.vivi@intel.com, airlied@linux.ie, daniel@ffwll.ch, farman@linux.ibm.com, pasic@linux.ibm.com, sebott@linux.ibm.com, oberpar@linux.ibm.com, heiko.carstens@de.ibm.com, gor@linux.ibm.com, borntraeger@de.ibm.com, akrowiak@linux.ibm.com, freude@linux.ibm.com, lingshan.zhu@intel.com, idos@mellanox.com, eperezma@redhat.com, lulu@redhat.com, parav@mellanox.com, christophe.de.dinechin@gmail.com, kevin.tian@intel.com, stefanha@redhat.com List-Id: dri-devel@lists.freedesktop.org This patch introduces a new mdev transport for virtio. This is used to use kernel virtio driver to drive the mediated device that is capable of populating virtqueue directly. A new virtio-mdev driver will be registered to the mdev bus, when a new virtio-mdev device is probed, it will register the device with mdev based config ops. This means it is a software transport between mdev driver and mdev device. The transport was implemented through virtio device specific ops. Reviewed-by: Cornelia Huck Signed-off-by: Jason Wang --- drivers/virtio/Kconfig | 13 ++ drivers/virtio/Makefile | 1 + drivers/virtio/virtio_mdev.c | 406 +++++++++++++++++++++++++++++++++++ 3 files changed, 420 insertions(+) create mode 100644 drivers/virtio/virtio_mdev.c diff --git a/drivers/virtio/Kconfig b/drivers/virtio/Kconfig index 078615cf2afc..bf526ce0facc 100644 --- a/drivers/virtio/Kconfig +++ b/drivers/virtio/Kconfig @@ -43,6 +43,19 @@ config VIRTIO_PCI_LEGACY =20 =09 If unsure, say Y. =20 +config VIRTIO_MDEV +=09tristate "MDEV driver for virtio devices" +=09depends on VFIO_MDEV && VIRTIO +=09default n +=09help +=09 This driver provides support for virtio based paravirtual +=09 device driver over MDEV bus. For this to be useful, you need +=09 an appropriate virtio mdev device implementation that +=09 operates on a physical device to allow the datapath of virtio +=09 to be offloaded to hardware. + +=09 If unsure, say M. + config VIRTIO_PMEM =09tristate "Support for virtio pmem driver" =09depends on VIRTIO diff --git a/drivers/virtio/Makefile b/drivers/virtio/Makefile index 3a2b5c5dcf46..f2997b6c812f 100644 --- a/drivers/virtio/Makefile +++ b/drivers/virtio/Makefile @@ -6,3 +6,4 @@ virtio_pci-y :=3D virtio_pci_modern.o virtio_pci_common.o virtio_pci-$(CONFIG_VIRTIO_PCI_LEGACY) +=3D virtio_pci_legacy.o obj-$(CONFIG_VIRTIO_BALLOON) +=3D virtio_balloon.o obj-$(CONFIG_VIRTIO_INPUT) +=3D virtio_input.o +obj-$(CONFIG_VIRTIO_MDEV) +=3D virtio_mdev.o diff --git a/drivers/virtio/virtio_mdev.c b/drivers/virtio/virtio_mdev.c new file mode 100644 index 000000000000..9e12ef240493 --- /dev/null +++ b/drivers/virtio/virtio_mdev.c @@ -0,0 +1,406 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * VIRTIO based driver for Mediated device + * + * Copyright (c) 2019, Red Hat. All rights reserved. + * Author: Jason Wang + * + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#define DRIVER_VERSION "0.1" +#define DRIVER_AUTHOR "Red Hat Corporation" +#define DRIVER_DESC "VIRTIO based driver for Mediated device" + +#define to_virtio_mdev_device(dev) \ +=09container_of(dev, struct virtio_mdev_device, vdev) + +struct virtio_mdev_device { +=09struct virtio_device vdev; +=09struct mdev_device *mdev; +=09u64 features; + +=09/* The lock to protect virtqueue list */ +=09spinlock_t lock; +=09/* List of virtio_mdev_vq_info */ +=09struct list_head virtqueues; +}; + +struct virtio_mdev_vq_info { +=09/* the actual virtqueue */ +=09struct virtqueue *vq; + +=09/* the list node for the virtqueues list */ +=09struct list_head node; +}; + +static struct mdev_device *vm_get_mdev(struct virtio_device *vdev) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; + +=09return mdev; +} + +static void virtio_mdev_get(struct virtio_device *vdev, unsigned offset, +=09=09=09 void *buf, unsigned len) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09ops->get_config(mdev, offset, buf, len); +} + +static void virtio_mdev_set(struct virtio_device *vdev, unsigned offset, +=09=09=09 const void *buf, unsigned len) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09ops->set_config(mdev, offset, buf, len); +} + +static u32 virtio_mdev_generation(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09if (ops->get_generation) +=09=09return ops->get_generation(mdev); + +=09return 0; +} + +static u8 virtio_mdev_get_status(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->get_status(mdev); +} + +static void virtio_mdev_set_status(struct virtio_device *vdev, u8 status) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->set_status(mdev, status); +} + +static void virtio_mdev_reset(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->set_status(mdev, 0); +} + +static bool virtio_mdev_notify(struct virtqueue *vq) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vq->vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09ops->kick_vq(mdev, vq->index); + +=09return true; +} + +static irqreturn_t virtio_mdev_config_cb(void *private) +{ +=09struct virtio_mdev_device *vm_dev =3D private; + +=09virtio_config_changed(&vm_dev->vdev); + +=09return IRQ_HANDLED; +} + +static irqreturn_t virtio_mdev_virtqueue_cb(void *private) +{ +=09struct virtio_mdev_vq_info *info =3D private; + +=09return vring_interrupt(0, info->vq); +} + +static struct virtqueue * +virtio_mdev_setup_vq(struct virtio_device *vdev, unsigned int index, +=09=09 void (*callback)(struct virtqueue *vq), +=09=09 const char *name, bool ctx) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_vq_info *info; +=09struct virtio_mdev_callback cb; +=09struct virtqueue *vq; +=09u64 desc_addr, driver_addr, device_addr; +=09unsigned long flags; +=09u32 align, num; +=09int err; + +=09if (!name) +=09=09return NULL; + +=09/* Queue shouldn't already be set up. */ +=09if (ops->get_vq_ready(mdev, index)) +=09=09return ERR_PTR(-ENOENT); + +=09/* Allocate and fill out our active queue description */ +=09info =3D kmalloc(sizeof(*info), GFP_KERNEL); +=09if (!info) +=09=09return ERR_PTR(-ENOMEM); + +=09num =3D ops->get_vq_num_max(mdev); +=09if (num =3D=3D 0) { +=09=09err =3D -ENOENT; +=09=09goto error_new_virtqueue; +=09} + +=09/* Create the vring */ +=09align =3D ops->get_vq_align(mdev); +=09vq =3D vring_create_virtqueue(index, num, align, vdev, +=09=09=09=09 true, true, ctx, +=09=09=09=09 virtio_mdev_notify, callback, name); +=09if (!vq) { +=09=09err =3D -ENOMEM; +=09=09goto error_new_virtqueue; +=09} + +=09/* Setup virtqueue callback */ +=09cb.callback =3D virtio_mdev_virtqueue_cb; +=09cb.private =3D info; +=09ops->set_vq_cb(mdev, index, &cb); +=09ops->set_vq_num(mdev, index, virtqueue_get_vring_size(vq)); + +=09desc_addr =3D virtqueue_get_desc_addr(vq); +=09driver_addr =3D virtqueue_get_avail_addr(vq); +=09device_addr =3D virtqueue_get_used_addr(vq); + +=09if (ops->set_vq_address(mdev, index, +=09=09=09=09desc_addr, driver_addr, +=09=09=09=09device_addr)) { +=09=09err =3D -EINVAL; +=09=09goto err_vq; +=09} + +=09ops->set_vq_ready(mdev, index, 1); + +=09vq->priv =3D info; +=09info->vq =3D vq; + +=09spin_lock_irqsave(&vm_dev->lock, flags); +=09list_add(&info->node, &vm_dev->virtqueues); +=09spin_unlock_irqrestore(&vm_dev->lock, flags); + +=09return vq; + +err_vq: +=09vring_del_virtqueue(vq); +error_new_virtqueue: +=09ops->set_vq_ready(mdev, index, 0); +=09WARN_ON(ops->get_vq_ready(mdev, index)); +=09kfree(info); +=09return ERR_PTR(err); +} + +static void virtio_mdev_del_vq(struct virtqueue *vq) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vq->vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_vq_info *info =3D vq->priv; +=09unsigned int index =3D vq->index; +=09unsigned long flags; + +=09spin_lock_irqsave(&vm_dev->lock, flags); +=09list_del(&info->node); +=09spin_unlock_irqrestore(&vm_dev->lock, flags); + +=09/* Select and deactivate the queue */ +=09ops->set_vq_ready(mdev, index, 0); +=09WARN_ON(ops->get_vq_ready(mdev, index)); + +=09vring_del_virtqueue(vq); + +=09kfree(info); +} + +static void virtio_mdev_del_vqs(struct virtio_device *vdev) +{ +=09struct virtqueue *vq, *n; + +=09list_for_each_entry_safe(vq, n, &vdev->vqs, list) +=09=09virtio_mdev_del_vq(vq); +} + +static int virtio_mdev_find_vqs(struct virtio_device *vdev, unsigned nvqs, +=09=09=09=09struct virtqueue *vqs[], +=09=09=09=09vq_callback_t *callbacks[], +=09=09=09=09const char * const names[], +=09=09=09=09const bool *ctx, +=09=09=09=09struct irq_affinity *desc) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_callback cb; +=09int i, err, queue_idx =3D 0; + +=09for (i =3D 0; i < nvqs; ++i) { +=09=09if (!names[i]) { +=09=09=09vqs[i] =3D NULL; +=09=09=09continue; +=09=09} + +=09=09vqs[i] =3D virtio_mdev_setup_vq(vdev, queue_idx++, +=09=09=09=09=09 callbacks[i], names[i], ctx ? +=09=09=09=09=09 ctx[i] : false); +=09=09if (IS_ERR(vqs[i])) { +=09=09=09err =3D PTR_ERR(vqs[i]); +=09=09=09goto err_setup_vq; +=09=09} +=09} + +=09cb.callback =3D virtio_mdev_config_cb; +=09cb.private =3D vm_dev; +=09ops->set_config_cb(mdev, &cb); + +=09return 0; + +err_setup_vq: +=09virtio_mdev_del_vqs(vdev); +=09return err; +} + +static u64 virtio_mdev_get_features(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09return ops->get_features(mdev); +} + +static int virtio_mdev_finalize_features(struct virtio_device *vdev) +{ +=09struct mdev_device *mdev =3D vm_get_mdev(vdev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); + +=09/* Give virtio_ring a chance to accept features. */ +=09vring_transport_features(vdev); + +=09return ops->set_features(mdev, vdev->features); +} + +static const char *virtio_mdev_bus_name(struct virtio_device *vdev) +{ +=09struct virtio_mdev_device *vm_dev =3D to_virtio_mdev_device(vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; + +=09return dev_name(mdev_dev(mdev)); +} + +static const struct virtio_config_ops virtio_mdev_config_ops =3D { +=09.get=09=09=3D virtio_mdev_get, +=09.set=09=09=3D virtio_mdev_set, +=09.generation=09=3D virtio_mdev_generation, +=09.get_status=09=3D virtio_mdev_get_status, +=09.set_status=09=3D virtio_mdev_set_status, +=09.reset=09=09=3D virtio_mdev_reset, +=09.find_vqs=09=3D virtio_mdev_find_vqs, +=09.del_vqs=09=3D virtio_mdev_del_vqs, +=09.get_features=09=3D virtio_mdev_get_features, +=09.finalize_features =3D virtio_mdev_finalize_features, +=09.bus_name=09=3D virtio_mdev_bus_name, +}; + +static void virtio_mdev_release_dev(struct device *_d) +{ +=09struct virtio_device *vdev =3D +=09 container_of(_d, struct virtio_device, dev); +=09struct virtio_mdev_device *vm_dev =3D +=09 container_of(vdev, struct virtio_mdev_device, vdev); +=09struct mdev_device *mdev =3D vm_dev->mdev; + +=09devm_kfree(mdev_dev(mdev), vm_dev); +} + +static int virtio_mdev_probe(struct device *dev) +{ +=09struct mdev_device *mdev =3D mdev_from_dev(dev); +=09const struct mdev_virtio_device_ops *ops =3D mdev_get_virtio_ops(mdev); +=09struct virtio_mdev_device *vm_dev; +=09int rc; + +=09vm_dev =3D devm_kzalloc(dev, sizeof(*vm_dev), GFP_KERNEL); +=09if (!vm_dev) +=09=09return -ENOMEM; + +=09vm_dev->vdev.dev.parent =3D dev; +=09vm_dev->vdev.dev.release =3D virtio_mdev_release_dev; +=09vm_dev->vdev.config =3D &virtio_mdev_config_ops; +=09vm_dev->mdev =3D mdev; +=09INIT_LIST_HEAD(&vm_dev->virtqueues); +=09spin_lock_init(&vm_dev->lock); + +=09vm_dev->vdev.id.device =3D ops->get_device_id(mdev); +=09if (vm_dev->vdev.id.device =3D=3D 0) +=09=09return -ENODEV; + +=09vm_dev->vdev.id.vendor =3D ops->get_vendor_id(mdev); +=09rc =3D register_virtio_device(&vm_dev->vdev); +=09if (rc) +=09=09put_device(dev); +=09else +=09=09dev_set_drvdata(dev, vm_dev); + +=09return rc; +} + +static void virtio_mdev_remove(struct device *dev) +{ +=09struct virtio_mdev_device *vm_dev =3D dev_get_drvdata(dev); + +=09unregister_virtio_device(&vm_dev->vdev); +} + +static const struct mdev_class_id virtio_id_table[] =3D { +=09{ MDEV_CLASS_ID_VIRTIO }, +=09{ 0 }, +}; + +MODULE_DEVICE_TABLE(mdev, virtio_id_table); + +static struct mdev_driver virtio_mdev_driver =3D { +=09.name=09=3D "virtio_mdev", +=09.probe=09=3D virtio_mdev_probe, +=09.remove =3D virtio_mdev_remove, +=09.id_table =3D virtio_id_table, +}; + +static int __init virtio_mdev_init(void) +{ +=09return mdev_register_driver(&virtio_mdev_driver, THIS_MODULE); +} + +static void __exit virtio_mdev_exit(void) +{ +=09mdev_unregister_driver(&virtio_mdev_driver); +} + +module_init(virtio_mdev_init) +module_exit(virtio_mdev_exit) + +MODULE_VERSION(DRIVER_VERSION); +MODULE_LICENSE("GPL v2"); +MODULE_AUTHOR(DRIVER_AUTHOR); +MODULE_DESCRIPTION(DRIVER_DESC); --=20 2.19.1 From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 02E1EC5DF64 for ; Wed, 6 Nov 2019 13:41:44 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id CF2E02166E for ; Wed, 6 Nov 2019 13:41:43 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org CF2E02166E Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=redhat.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 8B6286ED57; Wed, 6 Nov 2019 13:41:42 +0000 (UTC) Received: from us-smtp-delivery-1.mimecast.com (us-smtp-2.mimecast.com [207.211.31.81]) by gabe.freedesktop.org (Postfix) with ESMTPS id DBB866ED53 for ; Wed, 6 Nov 2019 13:41:40 +0000 (UTC) Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-37-ekA3G6WPOvC5qgCYmwwjcw-1; Wed, 06 Nov 2019 08:41:36 -0500 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id C23CB1800DFB; Wed, 6 Nov 2019 13:41:32 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-193.pek2.redhat.com [10.72.12.193]) by smtp.corp.redhat.com (Postfix) with ESMTP id 6C7B219756; Wed, 6 Nov 2019 13:41:04 +0000 (UTC) From: Jason Wang To: kvm@vger.kernel.org, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com, alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com Subject: [PATCH V10 5/6] virtio: introduce a mdev based transport Date: Wed, 6 Nov 2019 21:35:30 +0800 Message-Id: <20191106133531.693-6-jasowang@redhat.com> In-Reply-To: <20191106133531.693-1-jasowang@redhat.com> References: <20191106133531.693-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 X-MC-Unique: ekA3G6WPOvC5qgCYmwwjcw-1 X-Mimecast-Spam-Score: 0 X-Mailman-Original-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1573047699; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JGqg8qP39vMXnP+EB/M2jo3uCi2AD9tZlxsLNrs4jIY=; b=chmMjimA8DDpv+n1Qg8fF4UN+M5kRSVz5yMaefLPbjSA9/J6Vhom4qlFuriCbZFJXPiIA8 cldunI9DVoHKioSruFi5EG1WIKs1ZlaLhtvtJHQuWoqO6tVPAc3Scd21p+K1JyzL7ROqTT nusDO0Tyc75ZaKjuXzMwCKjOdpV0qwU= X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: christophe.de.dinechin@gmail.com, sebott@linux.ibm.com, airlied@linux.ie, Jason Wang , heiko.carstens@de.ibm.com, kevin.tian@intel.com, virtualization@lists.linux-foundation.org, rob.miller@broadcom.com, lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com, borntraeger@de.ibm.com, haotian.wang@sifive.com, zhi.a.wang@intel.com, farman@linux.ibm.com, idos@mellanox.com, gor@linux.ibm.com, cunming.liang@intel.com, rodrigo.vivi@intel.com, xiao.w.wang@intel.com, freude@linux.ibm.com, parav@mellanox.com, zhihong.wang@intel.com, stefanha@redhat.com, akrowiak@linux.ibm.com, netdev@vger.kernel.org, cohuck@redhat.com, oberpar@linux.ibm.com, maxime.coquelin@redhat.com, lingshan.zhu@intel.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" Message-ID: <20191106133530.0i3DJj50bnigKQV8LFq1Bl4ri0RiMJMJf600PHT3IsY@z> VGhpcyBwYXRjaCBpbnRyb2R1Y2VzIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZvciB2aXJ0aW8uIFRo aXMgaXMgdXNlZCB0bwp1c2Uga2VybmVsIHZpcnRpbyBkcml2ZXIgdG8gZHJpdmUgdGhlIG1lZGlh dGVkIGRldmljZSB0aGF0IGlzIGNhcGFibGUKb2YgcG9wdWxhdGluZyB2aXJ0cXVldWUgZGlyZWN0 bHkuCgpBIG5ldyB2aXJ0aW8tbWRldiBkcml2ZXIgd2lsbCBiZSByZWdpc3RlcmVkIHRvIHRoZSBt ZGV2IGJ1cywgd2hlbiBhCm5ldyB2aXJ0aW8tbWRldiBkZXZpY2UgaXMgcHJvYmVkLCBpdCB3aWxs IHJlZ2lzdGVyIHRoZSBkZXZpY2Ugd2l0aAptZGV2IGJhc2VkIGNvbmZpZyBvcHMuIFRoaXMgbWVh bnMgaXQgaXMgYSBzb2Z0d2FyZSB0cmFuc3BvcnQgYmV0d2VlbgptZGV2IGRyaXZlciBhbmQgbWRl diBkZXZpY2UuIFRoZSB0cmFuc3BvcnQgd2FzIGltcGxlbWVudGVkIHRocm91Z2gKdmlydGlvIGRl dmljZSBzcGVjaWZpYyBvcHMuCgpSZXZpZXdlZC1ieTogQ29ybmVsaWEgSHVjayA8Y29odWNrQHJl ZGhhdC5jb20+ClNpZ25lZC1vZmYtYnk6IEphc29uIFdhbmcgPGphc293YW5nQHJlZGhhdC5jb20+ Ci0tLQogZHJpdmVycy92aXJ0aW8vS2NvbmZpZyAgICAgICB8ICAxMyArKwogZHJpdmVycy92aXJ0 aW8vTWFrZWZpbGUgICAgICB8ICAgMSArCiBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jIHwg NDA2ICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrCiAzIGZpbGVzIGNoYW5nZWQs IDQyMCBpbnNlcnRpb25zKCspCiBjcmVhdGUgbW9kZSAxMDA2NDQgZHJpdmVycy92aXJ0aW8vdmly dGlvX21kZXYuYwoKZGlmZiAtLWdpdCBhL2RyaXZlcnMvdmlydGlvL0tjb25maWcgYi9kcml2ZXJz L3ZpcnRpby9LY29uZmlnCmluZGV4IDA3ODYxNWNmMmFmYy4uYmY1MjZjZTBmYWNjIDEwMDY0NAot LS0gYS9kcml2ZXJzL3ZpcnRpby9LY29uZmlnCisrKyBiL2RyaXZlcnMvdmlydGlvL0tjb25maWcK QEAgLTQzLDYgKzQzLDE5IEBAIGNvbmZpZyBWSVJUSU9fUENJX0xFR0FDWQogCiAJICBJZiB1bnN1 cmUsIHNheSBZLgogCitjb25maWcgVklSVElPX01ERVYKKwl0cmlzdGF0ZSAiTURFViBkcml2ZXIg Zm9yIHZpcnRpbyBkZXZpY2VzIgorCWRlcGVuZHMgb24gVkZJT19NREVWICYmIFZJUlRJTworCWRl ZmF1bHQgbgorCWhlbHAKKwkgIFRoaXMgZHJpdmVyIHByb3ZpZGVzIHN1cHBvcnQgZm9yIHZpcnRp byBiYXNlZCBwYXJhdmlydHVhbAorCSAgZGV2aWNlIGRyaXZlciBvdmVyIE1ERVYgYnVzLiBGb3Ig dGhpcyB0byBiZSB1c2VmdWwsIHlvdSBuZWVkCisJICBhbiBhcHByb3ByaWF0ZSB2aXJ0aW8gbWRl diBkZXZpY2UgaW1wbGVtZW50YXRpb24gdGhhdAorCSAgb3BlcmF0ZXMgb24gYSBwaHlzaWNhbCBk ZXZpY2UgdG8gYWxsb3cgdGhlIGRhdGFwYXRoIG9mIHZpcnRpbworCSAgdG8gYmUgb2ZmbG9hZGVk IHRvIGhhcmR3YXJlLgorCisJICBJZiB1bnN1cmUsIHNheSBNLgorCiBjb25maWcgVklSVElPX1BN RU0KIAl0cmlzdGF0ZSAiU3VwcG9ydCBmb3IgdmlydGlvIHBtZW0gZHJpdmVyIgogCWRlcGVuZHMg b24gVklSVElPCmRpZmYgLS1naXQgYS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZSBiL2RyaXZlcnMv dmlydGlvL01ha2VmaWxlCmluZGV4IDNhMmI1YzVkY2Y0Ni4uZjI5OTdiNmM4MTJmIDEwMDY0NAot LS0gYS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZQorKysgYi9kcml2ZXJzL3ZpcnRpby9NYWtlZmls ZQpAQCAtNiwzICs2LDQgQEAgdmlydGlvX3BjaS15IDo9IHZpcnRpb19wY2lfbW9kZXJuLm8gdmly dGlvX3BjaV9jb21tb24ubwogdmlydGlvX3BjaS0kKENPTkZJR19WSVJUSU9fUENJX0xFR0FDWSkg Kz0gdmlydGlvX3BjaV9sZWdhY3kubwogb2JqLSQoQ09ORklHX1ZJUlRJT19CQUxMT09OKSArPSB2 aXJ0aW9fYmFsbG9vbi5vCiBvYmotJChDT05GSUdfVklSVElPX0lOUFVUKSArPSB2aXJ0aW9faW5w dXQubworb2JqLSQoQ09ORklHX1ZJUlRJT19NREVWKSArPSB2aXJ0aW9fbWRldi5vCmRpZmYgLS1n aXQgYS9kcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jIGIvZHJpdmVycy92aXJ0aW8vdmlydGlv X21kZXYuYwpuZXcgZmlsZSBtb2RlIDEwMDY0NAppbmRleCAwMDAwMDAwMDAwMDAuLjllMTJlZjI0 MDQ5MwotLS0gL2Rldi9udWxsCisrKyBiL2RyaXZlcnMvdmlydGlvL3ZpcnRpb19tZGV2LmMKQEAg LTAsMCArMSw0MDYgQEAKKy8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBHUEwtMi4wLW9ubHkK Ky8qCisgKiBWSVJUSU8gYmFzZWQgZHJpdmVyIGZvciBNZWRpYXRlZCBkZXZpY2UKKyAqCisgKiBD b3B5cmlnaHQgKGMpIDIwMTksIFJlZCBIYXQuIEFsbCByaWdodHMgcmVzZXJ2ZWQuCisgKiAgICAg QXV0aG9yOiBKYXNvbiBXYW5nIDxqYXNvd2FuZ0ByZWRoYXQuY29tPgorICoKKyAqLworCisjaW5j bHVkZSA8bGludXgvaW5pdC5oPgorI2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgorI2luY2x1ZGUg PGxpbnV4L2RldmljZS5oPgorI2luY2x1ZGUgPGxpbnV4L2tlcm5lbC5oPgorI2luY2x1ZGUgPGxp bnV4L3NsYWIuaD4KKyNpbmNsdWRlIDxsaW51eC91dWlkLmg+CisjaW5jbHVkZSA8bGludXgvbWRl di5oPgorI2luY2x1ZGUgPGxpbnV4L21kZXZfdmlydGlvX29wcy5oPgorI2luY2x1ZGUgPGxpbnV4 L3ZpcnRpby5oPgorI2luY2x1ZGUgPGxpbnV4L3ZpcnRpb19jb25maWcuaD4KKyNpbmNsdWRlIDxs aW51eC92aXJ0aW9fcmluZy5oPgorCisjZGVmaW5lIERSSVZFUl9WRVJTSU9OICAiMC4xIgorI2Rl ZmluZSBEUklWRVJfQVVUSE9SICAgIlJlZCBIYXQgQ29ycG9yYXRpb24iCisjZGVmaW5lIERSSVZF Ul9ERVNDICAgICAiVklSVElPIGJhc2VkIGRyaXZlciBmb3IgTWVkaWF0ZWQgZGV2aWNlIgorCisj ZGVmaW5lIHRvX3ZpcnRpb19tZGV2X2RldmljZShkZXYpIFwKKwljb250YWluZXJfb2YoZGV2LCBz dHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlLCB2ZGV2KQorCitzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlIHsKKwlzdHJ1Y3QgdmlydGlvX2RldmljZSB2ZGV2OworCXN0cnVjdCBtZGV2X2RldmljZSAq bWRldjsKKwl1NjQgZmVhdHVyZXM7CisKKwkvKiBUaGUgbG9jayB0byBwcm90ZWN0IHZpcnRxdWV1 ZSBsaXN0ICovCisJc3BpbmxvY2tfdCBsb2NrOworCS8qIExpc3Qgb2YgdmlydGlvX21kZXZfdnFf aW5mbyAqLworCXN0cnVjdCBsaXN0X2hlYWQgdmlydHF1ZXVlczsKK307CisKK3N0cnVjdCB2aXJ0 aW9fbWRldl92cV9pbmZvIHsKKwkvKiB0aGUgYWN0dWFsIHZpcnRxdWV1ZSAqLworCXN0cnVjdCB2 aXJ0cXVldWUgKnZxOworCisJLyogdGhlIGxpc3Qgbm9kZSBmb3IgdGhlIHZpcnRxdWV1ZXMgbGlz dCAqLworCXN0cnVjdCBsaXN0X2hlYWQgbm9kZTsKK307CisKK3N0YXRpYyBzdHJ1Y3QgbWRldl9k ZXZpY2UgKnZtX2dldF9tZGV2KHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2KQoreworCXN0cnVj dCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2RldmljZSh2ZGV2 KTsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9kZXYtPm1kZXY7CisKKwlyZXR1cm4g bWRldjsKK30KKworc3RhdGljIHZvaWQgdmlydGlvX21kZXZfZ2V0KHN0cnVjdCB2aXJ0aW9fZGV2 aWNlICp2ZGV2LCB1bnNpZ25lZCBvZmZzZXQsCisJCQkgICAgdm9pZCAqYnVmLCB1bnNpZ25lZCBs ZW4pCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJ Y29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRp b19vcHMobWRldik7CisKKwlvcHMtPmdldF9jb25maWcobWRldiwgb2Zmc2V0LCBidWYsIGxlbik7 Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3NldChzdHJ1Y3QgdmlydGlvX2RldmljZSAq dmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJICAgIGNvbnN0IHZvaWQgKmJ1ZiwgdW5zaWduZWQg bGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOwor CWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92aXJ0 aW9fb3BzKG1kZXYpOworCisJb3BzLT5zZXRfY29uZmlnKG1kZXYsIG9mZnNldCwgYnVmLCBsZW4p OworfQorCitzdGF0aWMgdTMyIHZpcnRpb19tZGV2X2dlbmVyYXRpb24oc3RydWN0IHZpcnRpb19k ZXZpY2UgKnZkZXYpCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYo dmRldik7CisJY29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZf Z2V0X3ZpcnRpb19vcHMobWRldik7CisKKwlpZiAob3BzLT5nZXRfZ2VuZXJhdGlvbikKKwkJcmV0 dXJuIG9wcy0+Z2V0X2dlbmVyYXRpb24obWRldik7CisKKwlyZXR1cm4gMDsKK30KKworc3RhdGlj IHU4IHZpcnRpb19tZGV2X2dldF9zdGF0dXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7 CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qg c3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMo bWRldik7CisKKwlyZXR1cm4gb3BzLT5nZXRfc3RhdHVzKG1kZXYpOworfQorCitzdGF0aWMgdm9p ZCB2aXJ0aW9fbWRldl9zZXRfc3RhdHVzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2LCB1OCBz dGF0dXMpCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7 CisJY29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3Zp cnRpb19vcHMobWRldik7CisKKwlyZXR1cm4gb3BzLT5zZXRfc3RhdHVzKG1kZXYsIHN0YXR1cyk7 Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3Jlc2V0KHN0cnVjdCB2aXJ0aW9fZGV2aWNl ICp2ZGV2KQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYp OworCWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92 aXJ0aW9fb3BzKG1kZXYpOworCisJcmV0dXJuIG9wcy0+c2V0X3N0YXR1cyhtZGV2LCAwKTsKK30K Kworc3RhdGljIGJvb2wgdmlydGlvX21kZXZfbm90aWZ5KHN0cnVjdCB2aXJ0cXVldWUgKnZxKQor eworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZxLT52ZGV2KTsKKwlj b25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlv X29wcyhtZGV2KTsKKworCW9wcy0+a2lja192cShtZGV2LCB2cS0+aW5kZXgpOworCisJcmV0dXJu IHRydWU7Cit9CisKK3N0YXRpYyBpcnFyZXR1cm5fdCB2aXJ0aW9fbWRldl9jb25maWdfY2Iodm9p ZCAqcHJpdmF0ZSkKK3sKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSBwcml2 YXRlOworCisJdmlydGlvX2NvbmZpZ19jaGFuZ2VkKCZ2bV9kZXYtPnZkZXYpOworCisJcmV0dXJu IElSUV9IQU5ETEVEOworfQorCitzdGF0aWMgaXJxcmV0dXJuX3QgdmlydGlvX21kZXZfdmlydHF1 ZXVlX2NiKHZvaWQgKnByaXZhdGUpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X3ZxX2luZm8gKmlu Zm8gPSBwcml2YXRlOworCisJcmV0dXJuIHZyaW5nX2ludGVycnVwdCgwLCBpbmZvLT52cSk7Cit9 CisKK3N0YXRpYyBzdHJ1Y3QgdmlydHF1ZXVlICoKK3ZpcnRpb19tZGV2X3NldHVwX3ZxKHN0cnVj dCB2aXJ0aW9fZGV2aWNlICp2ZGV2LCB1bnNpZ25lZCBpbnQgaW5kZXgsCisJCSAgICAgdm9pZCAo KmNhbGxiYWNrKShzdHJ1Y3QgdmlydHF1ZXVlICp2cSksCisJCSAgICAgY29uc3QgY2hhciAqbmFt ZSwgYm9vbCBjdHgpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0gdG9f dmlydGlvX21kZXZfZGV2aWNlKHZkZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZt X2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19kZXZpY2Vfb3BzICpv cHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCXN0cnVjdCB2aXJ0aW9fbWRldl92cV9p bmZvICppbmZvOworCXN0cnVjdCB2aXJ0aW9fbWRldl9jYWxsYmFjayBjYjsKKwlzdHJ1Y3Qgdmly dHF1ZXVlICp2cTsKKwl1NjQgZGVzY19hZGRyLCBkcml2ZXJfYWRkciwgZGV2aWNlX2FkZHI7CisJ dW5zaWduZWQgbG9uZyBmbGFnczsKKwl1MzIgYWxpZ24sIG51bTsKKwlpbnQgZXJyOworCisJaWYg KCFuYW1lKQorCQlyZXR1cm4gTlVMTDsKKworCS8qIFF1ZXVlIHNob3VsZG4ndCBhbHJlYWR5IGJl IHNldCB1cC4gKi8KKwlpZiAob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKQorCQlyZXR1 cm4gRVJSX1BUUigtRU5PRU5UKTsKKworCS8qIEFsbG9jYXRlIGFuZCBmaWxsIG91dCBvdXIgYWN0 aXZlIHF1ZXVlIGRlc2NyaXB0aW9uICovCisJaW5mbyA9IGttYWxsb2Moc2l6ZW9mKCppbmZvKSwg R0ZQX0tFUk5FTCk7CisJaWYgKCFpbmZvKQorCQlyZXR1cm4gRVJSX1BUUigtRU5PTUVNKTsKKwor CW51bSA9IG9wcy0+Z2V0X3ZxX251bV9tYXgobWRldik7CisJaWYgKG51bSA9PSAwKSB7CisJCWVy ciA9IC1FTk9FTlQ7CisJCWdvdG8gZXJyb3JfbmV3X3ZpcnRxdWV1ZTsKKwl9CisKKwkvKiBDcmVh dGUgdGhlIHZyaW5nICovCisJYWxpZ24gPSBvcHMtPmdldF92cV9hbGlnbihtZGV2KTsKKwl2cSA9 IHZyaW5nX2NyZWF0ZV92aXJ0cXVldWUoaW5kZXgsIG51bSwgYWxpZ24sIHZkZXYsCisJCQkJICAg IHRydWUsIHRydWUsIGN0eCwKKwkJCQkgICAgdmlydGlvX21kZXZfbm90aWZ5LCBjYWxsYmFjaywg bmFtZSk7CisJaWYgKCF2cSkgeworCQllcnIgPSAtRU5PTUVNOworCQlnb3RvIGVycm9yX25ld192 aXJ0cXVldWU7CisJfQorCisJLyogU2V0dXAgdmlydHF1ZXVlIGNhbGxiYWNrICovCisJY2IuY2Fs bGJhY2sgPSB2aXJ0aW9fbWRldl92aXJ0cXVldWVfY2I7CisJY2IucHJpdmF0ZSA9IGluZm87CisJ b3BzLT5zZXRfdnFfY2IobWRldiwgaW5kZXgsICZjYik7CisJb3BzLT5zZXRfdnFfbnVtKG1kZXYs IGluZGV4LCB2aXJ0cXVldWVfZ2V0X3ZyaW5nX3NpemUodnEpKTsKKworCWRlc2NfYWRkciA9IHZp cnRxdWV1ZV9nZXRfZGVzY19hZGRyKHZxKTsKKwlkcml2ZXJfYWRkciA9IHZpcnRxdWV1ZV9nZXRf YXZhaWxfYWRkcih2cSk7CisJZGV2aWNlX2FkZHIgPSB2aXJ0cXVldWVfZ2V0X3VzZWRfYWRkcih2 cSk7CisKKwlpZiAob3BzLT5zZXRfdnFfYWRkcmVzcyhtZGV2LCBpbmRleCwKKwkJCQlkZXNjX2Fk ZHIsIGRyaXZlcl9hZGRyLAorCQkJCWRldmljZV9hZGRyKSkgeworCQllcnIgPSAtRUlOVkFMOwor CQlnb3RvIGVycl92cTsKKwl9CisKKwlvcHMtPnNldF92cV9yZWFkeShtZGV2LCBpbmRleCwgMSk7 CisKKwl2cS0+cHJpdiA9IGluZm87CisJaW5mby0+dnEgPSB2cTsKKworCXNwaW5fbG9ja19pcnFz YXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2FkZCgmaW5mby0+bm9kZSwgJnZtX2Rl di0+dmlydHF1ZXVlcyk7CisJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmdm1fZGV2LT5sb2NrLCBm bGFncyk7CisKKwlyZXR1cm4gdnE7CisKK2Vycl92cToKKwl2cmluZ19kZWxfdmlydHF1ZXVlKHZx KTsKK2Vycm9yX25ld192aXJ0cXVldWU6CisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwgaW5kZXgs IDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKTsKKwlrZnJlZShp bmZvKTsKKwlyZXR1cm4gRVJSX1BUUihlcnIpOworfQorCitzdGF0aWMgdm9pZCB2aXJ0aW9fbWRl dl9kZWxfdnEoc3RydWN0IHZpcnRxdWV1ZSAqdnEpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2Rl dmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZxLT52ZGV2KTsKKwlzdHJ1Y3Qg bWRldl9kZXZpY2UgKm1kZXYgPSB2bV9kZXYtPm1kZXY7CisJY29uc3Qgc3RydWN0IG1kZXZfdmly dGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRldik7CisJc3RydWN0 IHZpcnRpb19tZGV2X3ZxX2luZm8gKmluZm8gPSB2cS0+cHJpdjsKKwl1bnNpZ25lZCBpbnQgaW5k ZXggPSB2cS0+aW5kZXg7CisJdW5zaWduZWQgbG9uZyBmbGFnczsKKworCXNwaW5fbG9ja19pcnFz YXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2RlbCgmaW5mby0+bm9kZSk7CisJc3Bp bl91bmxvY2tfaXJxcmVzdG9yZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisKKwkvKiBTZWxlY3Qg YW5kIGRlYWN0aXZhdGUgdGhlIHF1ZXVlICovCisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwgaW5k ZXgsIDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKTsKKworCXZy aW5nX2RlbF92aXJ0cXVldWUodnEpOworCisJa2ZyZWUoaW5mbyk7Cit9CisKK3N0YXRpYyB2b2lk IHZpcnRpb19tZGV2X2RlbF92cXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3Ry dWN0IHZpcnRxdWV1ZSAqdnEsICpuOworCisJbGlzdF9mb3JfZWFjaF9lbnRyeV9zYWZlKHZxLCBu LCAmdmRldi0+dnFzLCBsaXN0KQorCQl2aXJ0aW9fbWRldl9kZWxfdnEodnEpOworfQorCitzdGF0 aWMgaW50IHZpcnRpb19tZGV2X2ZpbmRfdnFzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2LCB1 bnNpZ25lZCBudnFzLAorCQkJCXN0cnVjdCB2aXJ0cXVldWUgKnZxc1tdLAorCQkJCXZxX2NhbGxi YWNrX3QgKmNhbGxiYWNrc1tdLAorCQkJCWNvbnN0IGNoYXIgKiBjb25zdCBuYW1lc1tdLAorCQkJ CWNvbnN0IGJvb2wgKmN0eCwKKwkJCQlzdHJ1Y3QgaXJxX2FmZmluaXR5ICpkZXNjKQoreworCXN0 cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2RldmljZSh2 ZGV2KTsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwlj b25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlv X29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfY2FsbGJhY2sgY2I7CisJaW50IGksIGVy ciwgcXVldWVfaWR4ID0gMDsKKworCWZvciAoaSA9IDA7IGkgPCBudnFzOyArK2kpIHsKKwkJaWYg KCFuYW1lc1tpXSkgeworCQkJdnFzW2ldID0gTlVMTDsKKwkJCWNvbnRpbnVlOworCQl9CisKKwkJ dnFzW2ldID0gdmlydGlvX21kZXZfc2V0dXBfdnEodmRldiwgcXVldWVfaWR4KyssCisJCQkJCSAg ICAgIGNhbGxiYWNrc1tpXSwgbmFtZXNbaV0sIGN0eCA/CisJCQkJCSAgICAgIGN0eFtpXSA6IGZh bHNlKTsKKwkJaWYgKElTX0VSUih2cXNbaV0pKSB7CisJCQllcnIgPSBQVFJfRVJSKHZxc1tpXSk7 CisJCQlnb3RvIGVycl9zZXR1cF92cTsKKwkJfQorCX0KKworCWNiLmNhbGxiYWNrID0gdmlydGlv X21kZXZfY29uZmlnX2NiOworCWNiLnByaXZhdGUgPSB2bV9kZXY7CisJb3BzLT5zZXRfY29uZmln X2NiKG1kZXYsICZjYik7CisKKwlyZXR1cm4gMDsKKworZXJyX3NldHVwX3ZxOgorCXZpcnRpb19t ZGV2X2RlbF92cXModmRldik7CisJcmV0dXJuIGVycjsKK30KKworc3RhdGljIHU2NCB2aXJ0aW9f bWRldl9nZXRfZmVhdHVyZXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3RydWN0 IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3RydWN0IG1k ZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRldik7CisK KwlyZXR1cm4gb3BzLT5nZXRfZmVhdHVyZXMobWRldik7Cit9CisKK3N0YXRpYyBpbnQgdmlydGlv X21kZXZfZmluYWxpemVfZmVhdHVyZXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJ c3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3Ry dWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRl dik7CisKKwkvKiBHaXZlIHZpcnRpb19yaW5nIGEgY2hhbmNlIHRvIGFjY2VwdCBmZWF0dXJlcy4g Ki8KKwl2cmluZ190cmFuc3BvcnRfZmVhdHVyZXModmRldik7CisKKwlyZXR1cm4gb3BzLT5zZXRf ZmVhdHVyZXMobWRldiwgdmRldi0+ZmVhdHVyZXMpOworfQorCitzdGF0aWMgY29uc3QgY2hhciAq dmlydGlvX21kZXZfYnVzX25hbWUoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3Ry dWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZk ZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsKKworCXJldHVy biBkZXZfbmFtZShtZGV2X2RldihtZGV2KSk7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3Qgdmly dGlvX2NvbmZpZ19vcHMgdmlydGlvX21kZXZfY29uZmlnX29wcyA9IHsKKwkuZ2V0CQk9IHZpcnRp b19tZGV2X2dldCwKKwkuc2V0CQk9IHZpcnRpb19tZGV2X3NldCwKKwkuZ2VuZXJhdGlvbgk9IHZp cnRpb19tZGV2X2dlbmVyYXRpb24sCisJLmdldF9zdGF0dXMJPSB2aXJ0aW9fbWRldl9nZXRfc3Rh dHVzLAorCS5zZXRfc3RhdHVzCT0gdmlydGlvX21kZXZfc2V0X3N0YXR1cywKKwkucmVzZXQJCT0g dmlydGlvX21kZXZfcmVzZXQsCisJLmZpbmRfdnFzCT0gdmlydGlvX21kZXZfZmluZF92cXMsCisJ LmRlbF92cXMJPSB2aXJ0aW9fbWRldl9kZWxfdnFzLAorCS5nZXRfZmVhdHVyZXMJPSB2aXJ0aW9f bWRldl9nZXRfZmVhdHVyZXMsCisJLmZpbmFsaXplX2ZlYXR1cmVzID0gdmlydGlvX21kZXZfZmlu YWxpemVfZmVhdHVyZXMsCisJLmJ1c19uYW1lCT0gdmlydGlvX21kZXZfYnVzX25hbWUsCit9Owor CitzdGF0aWMgdm9pZCB2aXJ0aW9fbWRldl9yZWxlYXNlX2RldihzdHJ1Y3QgZGV2aWNlICpfZCkK K3sKKwlzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldiA9CisJICAgICAgIGNvbnRhaW5lcl9vZihf ZCwgc3RydWN0IHZpcnRpb19kZXZpY2UsIGRldik7CisJc3RydWN0IHZpcnRpb19tZGV2X2Rldmlj ZSAqdm1fZGV2ID0KKwkgICAgICAgY29udGFpbmVyX29mKHZkZXYsIHN0cnVjdCB2aXJ0aW9fbWRl dl9kZXZpY2UsIHZkZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRl djsKKworCWRldm1fa2ZyZWUobWRldl9kZXYobWRldiksIHZtX2Rldik7Cit9CisKK3N0YXRpYyBp bnQgdmlydGlvX21kZXZfcHJvYmUoc3RydWN0IGRldmljZSAqZGV2KQoreworCXN0cnVjdCBtZGV2 X2RldmljZSAqbWRldiA9IG1kZXZfZnJvbV9kZXYoZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92 aXJ0aW9fZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlvX29wcyhtZGV2KTsKKwlzdHJ1 Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXY7CisJaW50IHJjOworCisJdm1fZGV2ID0gZGV2 bV9remFsbG9jKGRldiwgc2l6ZW9mKCp2bV9kZXYpLCBHRlBfS0VSTkVMKTsKKwlpZiAoIXZtX2Rl dikKKwkJcmV0dXJuIC1FTk9NRU07CisKKwl2bV9kZXYtPnZkZXYuZGV2LnBhcmVudCA9IGRldjsK Kwl2bV9kZXYtPnZkZXYuZGV2LnJlbGVhc2UgPSB2aXJ0aW9fbWRldl9yZWxlYXNlX2RldjsKKwl2 bV9kZXYtPnZkZXYuY29uZmlnID0gJnZpcnRpb19tZGV2X2NvbmZpZ19vcHM7CisJdm1fZGV2LT5t ZGV2ID0gbWRldjsKKwlJTklUX0xJU1RfSEVBRCgmdm1fZGV2LT52aXJ0cXVldWVzKTsKKwlzcGlu X2xvY2tfaW5pdCgmdm1fZGV2LT5sb2NrKTsKKworCXZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPSBv cHMtPmdldF9kZXZpY2VfaWQobWRldik7CisJaWYgKHZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPT0g MCkKKwkJcmV0dXJuIC1FTk9ERVY7CisKKwl2bV9kZXYtPnZkZXYuaWQudmVuZG9yID0gb3BzLT5n ZXRfdmVuZG9yX2lkKG1kZXYpOworCXJjID0gcmVnaXN0ZXJfdmlydGlvX2RldmljZSgmdm1fZGV2 LT52ZGV2KTsKKwlpZiAocmMpCisJCXB1dF9kZXZpY2UoZGV2KTsKKwllbHNlCisJCWRldl9zZXRf ZHJ2ZGF0YShkZXYsIHZtX2Rldik7CisKKwlyZXR1cm4gcmM7Cit9CisKK3N0YXRpYyB2b2lkIHZp cnRpb19tZGV2X3JlbW92ZShzdHJ1Y3QgZGV2aWNlICpkZXYpCit7CisJc3RydWN0IHZpcnRpb19t ZGV2X2RldmljZSAqdm1fZGV2ID0gZGV2X2dldF9kcnZkYXRhKGRldik7CisKKwl1bnJlZ2lzdGVy X3ZpcnRpb19kZXZpY2UoJnZtX2Rldi0+dmRldik7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3Qg bWRldl9jbGFzc19pZCB2aXJ0aW9faWRfdGFibGVbXSA9IHsKKwl7IE1ERVZfQ0xBU1NfSURfVklS VElPIH0sCisJeyAwIH0sCit9OworCitNT0RVTEVfREVWSUNFX1RBQkxFKG1kZXYsIHZpcnRpb19p ZF90YWJsZSk7CisKK3N0YXRpYyBzdHJ1Y3QgbWRldl9kcml2ZXIgdmlydGlvX21kZXZfZHJpdmVy ID0geworCS5uYW1lCT0gInZpcnRpb19tZGV2IiwKKwkucHJvYmUJPSB2aXJ0aW9fbWRldl9wcm9i ZSwKKwkucmVtb3ZlID0gdmlydGlvX21kZXZfcmVtb3ZlLAorCS5pZF90YWJsZSA9IHZpcnRpb19p ZF90YWJsZSwKK307CisKK3N0YXRpYyBpbnQgX19pbml0IHZpcnRpb19tZGV2X2luaXQodm9pZCkK K3sKKwlyZXR1cm4gbWRldl9yZWdpc3Rlcl9kcml2ZXIoJnZpcnRpb19tZGV2X2RyaXZlciwgVEhJ U19NT0RVTEUpOworfQorCitzdGF0aWMgdm9pZCBfX2V4aXQgdmlydGlvX21kZXZfZXhpdCh2b2lk KQoreworCW1kZXZfdW5yZWdpc3Rlcl9kcml2ZXIoJnZpcnRpb19tZGV2X2RyaXZlcik7Cit9CisK K21vZHVsZV9pbml0KHZpcnRpb19tZGV2X2luaXQpCittb2R1bGVfZXhpdCh2aXJ0aW9fbWRldl9l eGl0KQorCitNT0RVTEVfVkVSU0lPTihEUklWRVJfVkVSU0lPTik7CitNT0RVTEVfTElDRU5TRSgi R1BMIHYyIik7CitNT0RVTEVfQVVUSE9SKERSSVZFUl9BVVRIT1IpOworTU9EVUxFX0RFU0NSSVBU SU9OKERSSVZFUl9ERVNDKTsKLS0gCjIuMTkuMQoKX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX18KZHJpLWRldmVsIG1haWxpbmcgbGlzdApkcmktZGV2ZWxAbGlz dHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBzOi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4v bGlzdGluZm8vZHJpLWRldmVs From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8E251C5DF63 for ; Wed, 6 Nov 2019 13:41:43 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 672512166E for ; Wed, 6 Nov 2019 13:41:43 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 672512166E Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=redhat.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=intel-gfx-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 7A6486ED53; Wed, 6 Nov 2019 13:41:42 +0000 (UTC) Received: from us-smtp-delivery-1.mimecast.com (us-smtp-2.mimecast.com [207.211.31.81]) by gabe.freedesktop.org (Postfix) with ESMTPS id E88C36ED57 for ; Wed, 6 Nov 2019 13:41:40 +0000 (UTC) Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-37-ekA3G6WPOvC5qgCYmwwjcw-1; Wed, 06 Nov 2019 08:41:36 -0500 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id C23CB1800DFB; Wed, 6 Nov 2019 13:41:32 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-193.pek2.redhat.com [10.72.12.193]) by smtp.corp.redhat.com (Postfix) with ESMTP id 6C7B219756; Wed, 6 Nov 2019 13:41:04 +0000 (UTC) From: Jason Wang To: kvm@vger.kernel.org, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com, alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com Date: Wed, 6 Nov 2019 21:35:30 +0800 Message-Id: <20191106133531.693-6-jasowang@redhat.com> In-Reply-To: <20191106133531.693-1-jasowang@redhat.com> References: <20191106133531.693-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 X-MC-Unique: ekA3G6WPOvC5qgCYmwwjcw-1 X-Mimecast-Spam-Score: 0 X-Mailman-Original-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1573047700; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=JGqg8qP39vMXnP+EB/M2jo3uCi2AD9tZlxsLNrs4jIY=; b=B17VlhHd2HRHMry7nO0Mh+TXlffs3u9E14fte86vI1+WStmwnqnKq2qAAYTPvzTz5JV6Yy zuRFSHvq+QOZ+zPowkejRLbA7YUUOPXMTepY2nVIj2r3rVjYFxbOFEo9acrXwL+j7Q1frS ATdS8d2zPQtYEmJt9BM9209s8sIgpac= Subject: [Intel-gfx] [PATCH V10 5/6] virtio: introduce a mdev based transport X-BeenThere: intel-gfx@lists.freedesktop.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Intel graphics driver community testing & development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: christophe.de.dinechin@gmail.com, sebott@linux.ibm.com, airlied@linux.ie, Jason Wang , heiko.carstens@de.ibm.com, virtualization@lists.linux-foundation.org, rob.miller@broadcom.com, lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com, borntraeger@de.ibm.com, haotian.wang@sifive.com, farman@linux.ibm.com, idos@mellanox.com, gor@linux.ibm.com, cunming.liang@intel.com, xiao.w.wang@intel.com, freude@linux.ibm.com, parav@mellanox.com, zhihong.wang@intel.com, stefanha@redhat.com, akrowiak@linux.ibm.com, netdev@vger.kernel.org, cohuck@redhat.com, oberpar@linux.ibm.com, maxime.coquelin@redhat.com, lingshan.zhu@intel.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" Message-ID: <20191106133530.1j-qXci65vJO8nGf8TvXZ8b-qwNu8JET1UE3zpXN9xs@z> VGhpcyBwYXRjaCBpbnRyb2R1Y2VzIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZvciB2aXJ0aW8uIFRo aXMgaXMgdXNlZCB0bwp1c2Uga2VybmVsIHZpcnRpbyBkcml2ZXIgdG8gZHJpdmUgdGhlIG1lZGlh dGVkIGRldmljZSB0aGF0IGlzIGNhcGFibGUKb2YgcG9wdWxhdGluZyB2aXJ0cXVldWUgZGlyZWN0 bHkuCgpBIG5ldyB2aXJ0aW8tbWRldiBkcml2ZXIgd2lsbCBiZSByZWdpc3RlcmVkIHRvIHRoZSBt ZGV2IGJ1cywgd2hlbiBhCm5ldyB2aXJ0aW8tbWRldiBkZXZpY2UgaXMgcHJvYmVkLCBpdCB3aWxs IHJlZ2lzdGVyIHRoZSBkZXZpY2Ugd2l0aAptZGV2IGJhc2VkIGNvbmZpZyBvcHMuIFRoaXMgbWVh bnMgaXQgaXMgYSBzb2Z0d2FyZSB0cmFuc3BvcnQgYmV0d2VlbgptZGV2IGRyaXZlciBhbmQgbWRl diBkZXZpY2UuIFRoZSB0cmFuc3BvcnQgd2FzIGltcGxlbWVudGVkIHRocm91Z2gKdmlydGlvIGRl dmljZSBzcGVjaWZpYyBvcHMuCgpSZXZpZXdlZC1ieTogQ29ybmVsaWEgSHVjayA8Y29odWNrQHJl ZGhhdC5jb20+ClNpZ25lZC1vZmYtYnk6IEphc29uIFdhbmcgPGphc293YW5nQHJlZGhhdC5jb20+ Ci0tLQogZHJpdmVycy92aXJ0aW8vS2NvbmZpZyAgICAgICB8ICAxMyArKwogZHJpdmVycy92aXJ0 aW8vTWFrZWZpbGUgICAgICB8ICAgMSArCiBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jIHwg NDA2ICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrCiAzIGZpbGVzIGNoYW5nZWQs IDQyMCBpbnNlcnRpb25zKCspCiBjcmVhdGUgbW9kZSAxMDA2NDQgZHJpdmVycy92aXJ0aW8vdmly dGlvX21kZXYuYwoKZGlmZiAtLWdpdCBhL2RyaXZlcnMvdmlydGlvL0tjb25maWcgYi9kcml2ZXJz L3ZpcnRpby9LY29uZmlnCmluZGV4IDA3ODYxNWNmMmFmYy4uYmY1MjZjZTBmYWNjIDEwMDY0NAot LS0gYS9kcml2ZXJzL3ZpcnRpby9LY29uZmlnCisrKyBiL2RyaXZlcnMvdmlydGlvL0tjb25maWcK QEAgLTQzLDYgKzQzLDE5IEBAIGNvbmZpZyBWSVJUSU9fUENJX0xFR0FDWQogCiAJICBJZiB1bnN1 cmUsIHNheSBZLgogCitjb25maWcgVklSVElPX01ERVYKKwl0cmlzdGF0ZSAiTURFViBkcml2ZXIg Zm9yIHZpcnRpbyBkZXZpY2VzIgorCWRlcGVuZHMgb24gVkZJT19NREVWICYmIFZJUlRJTworCWRl ZmF1bHQgbgorCWhlbHAKKwkgIFRoaXMgZHJpdmVyIHByb3ZpZGVzIHN1cHBvcnQgZm9yIHZpcnRp byBiYXNlZCBwYXJhdmlydHVhbAorCSAgZGV2aWNlIGRyaXZlciBvdmVyIE1ERVYgYnVzLiBGb3Ig dGhpcyB0byBiZSB1c2VmdWwsIHlvdSBuZWVkCisJICBhbiBhcHByb3ByaWF0ZSB2aXJ0aW8gbWRl diBkZXZpY2UgaW1wbGVtZW50YXRpb24gdGhhdAorCSAgb3BlcmF0ZXMgb24gYSBwaHlzaWNhbCBk ZXZpY2UgdG8gYWxsb3cgdGhlIGRhdGFwYXRoIG9mIHZpcnRpbworCSAgdG8gYmUgb2ZmbG9hZGVk IHRvIGhhcmR3YXJlLgorCisJICBJZiB1bnN1cmUsIHNheSBNLgorCiBjb25maWcgVklSVElPX1BN RU0KIAl0cmlzdGF0ZSAiU3VwcG9ydCBmb3IgdmlydGlvIHBtZW0gZHJpdmVyIgogCWRlcGVuZHMg b24gVklSVElPCmRpZmYgLS1naXQgYS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZSBiL2RyaXZlcnMv dmlydGlvL01ha2VmaWxlCmluZGV4IDNhMmI1YzVkY2Y0Ni4uZjI5OTdiNmM4MTJmIDEwMDY0NAot LS0gYS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZQorKysgYi9kcml2ZXJzL3ZpcnRpby9NYWtlZmls ZQpAQCAtNiwzICs2LDQgQEAgdmlydGlvX3BjaS15IDo9IHZpcnRpb19wY2lfbW9kZXJuLm8gdmly dGlvX3BjaV9jb21tb24ubwogdmlydGlvX3BjaS0kKENPTkZJR19WSVJUSU9fUENJX0xFR0FDWSkg Kz0gdmlydGlvX3BjaV9sZWdhY3kubwogb2JqLSQoQ09ORklHX1ZJUlRJT19CQUxMT09OKSArPSB2 aXJ0aW9fYmFsbG9vbi5vCiBvYmotJChDT05GSUdfVklSVElPX0lOUFVUKSArPSB2aXJ0aW9faW5w dXQubworb2JqLSQoQ09ORklHX1ZJUlRJT19NREVWKSArPSB2aXJ0aW9fbWRldi5vCmRpZmYgLS1n aXQgYS9kcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jIGIvZHJpdmVycy92aXJ0aW8vdmlydGlv X21kZXYuYwpuZXcgZmlsZSBtb2RlIDEwMDY0NAppbmRleCAwMDAwMDAwMDAwMDAuLjllMTJlZjI0 MDQ5MwotLS0gL2Rldi9udWxsCisrKyBiL2RyaXZlcnMvdmlydGlvL3ZpcnRpb19tZGV2LmMKQEAg LTAsMCArMSw0MDYgQEAKKy8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBHUEwtMi4wLW9ubHkK Ky8qCisgKiBWSVJUSU8gYmFzZWQgZHJpdmVyIGZvciBNZWRpYXRlZCBkZXZpY2UKKyAqCisgKiBD b3B5cmlnaHQgKGMpIDIwMTksIFJlZCBIYXQuIEFsbCByaWdodHMgcmVzZXJ2ZWQuCisgKiAgICAg QXV0aG9yOiBKYXNvbiBXYW5nIDxqYXNvd2FuZ0ByZWRoYXQuY29tPgorICoKKyAqLworCisjaW5j bHVkZSA8bGludXgvaW5pdC5oPgorI2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgorI2luY2x1ZGUg PGxpbnV4L2RldmljZS5oPgorI2luY2x1ZGUgPGxpbnV4L2tlcm5lbC5oPgorI2luY2x1ZGUgPGxp bnV4L3NsYWIuaD4KKyNpbmNsdWRlIDxsaW51eC91dWlkLmg+CisjaW5jbHVkZSA8bGludXgvbWRl di5oPgorI2luY2x1ZGUgPGxpbnV4L21kZXZfdmlydGlvX29wcy5oPgorI2luY2x1ZGUgPGxpbnV4 L3ZpcnRpby5oPgorI2luY2x1ZGUgPGxpbnV4L3ZpcnRpb19jb25maWcuaD4KKyNpbmNsdWRlIDxs aW51eC92aXJ0aW9fcmluZy5oPgorCisjZGVmaW5lIERSSVZFUl9WRVJTSU9OICAiMC4xIgorI2Rl ZmluZSBEUklWRVJfQVVUSE9SICAgIlJlZCBIYXQgQ29ycG9yYXRpb24iCisjZGVmaW5lIERSSVZF Ul9ERVNDICAgICAiVklSVElPIGJhc2VkIGRyaXZlciBmb3IgTWVkaWF0ZWQgZGV2aWNlIgorCisj ZGVmaW5lIHRvX3ZpcnRpb19tZGV2X2RldmljZShkZXYpIFwKKwljb250YWluZXJfb2YoZGV2LCBz dHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlLCB2ZGV2KQorCitzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlIHsKKwlzdHJ1Y3QgdmlydGlvX2RldmljZSB2ZGV2OworCXN0cnVjdCBtZGV2X2RldmljZSAq bWRldjsKKwl1NjQgZmVhdHVyZXM7CisKKwkvKiBUaGUgbG9jayB0byBwcm90ZWN0IHZpcnRxdWV1 ZSBsaXN0ICovCisJc3BpbmxvY2tfdCBsb2NrOworCS8qIExpc3Qgb2YgdmlydGlvX21kZXZfdnFf aW5mbyAqLworCXN0cnVjdCBsaXN0X2hlYWQgdmlydHF1ZXVlczsKK307CisKK3N0cnVjdCB2aXJ0 aW9fbWRldl92cV9pbmZvIHsKKwkvKiB0aGUgYWN0dWFsIHZpcnRxdWV1ZSAqLworCXN0cnVjdCB2 aXJ0cXVldWUgKnZxOworCisJLyogdGhlIGxpc3Qgbm9kZSBmb3IgdGhlIHZpcnRxdWV1ZXMgbGlz dCAqLworCXN0cnVjdCBsaXN0X2hlYWQgbm9kZTsKK307CisKK3N0YXRpYyBzdHJ1Y3QgbWRldl9k ZXZpY2UgKnZtX2dldF9tZGV2KHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2KQoreworCXN0cnVj dCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2RldmljZSh2ZGV2 KTsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9kZXYtPm1kZXY7CisKKwlyZXR1cm4g bWRldjsKK30KKworc3RhdGljIHZvaWQgdmlydGlvX21kZXZfZ2V0KHN0cnVjdCB2aXJ0aW9fZGV2 aWNlICp2ZGV2LCB1bnNpZ25lZCBvZmZzZXQsCisJCQkgICAgdm9pZCAqYnVmLCB1bnNpZ25lZCBs ZW4pCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJ Y29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRp b19vcHMobWRldik7CisKKwlvcHMtPmdldF9jb25maWcobWRldiwgb2Zmc2V0LCBidWYsIGxlbik7 Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3NldChzdHJ1Y3QgdmlydGlvX2RldmljZSAq dmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJICAgIGNvbnN0IHZvaWQgKmJ1ZiwgdW5zaWduZWQg bGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOwor CWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92aXJ0 aW9fb3BzKG1kZXYpOworCisJb3BzLT5zZXRfY29uZmlnKG1kZXYsIG9mZnNldCwgYnVmLCBsZW4p OworfQorCitzdGF0aWMgdTMyIHZpcnRpb19tZGV2X2dlbmVyYXRpb24oc3RydWN0IHZpcnRpb19k ZXZpY2UgKnZkZXYpCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYo dmRldik7CisJY29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZf Z2V0X3ZpcnRpb19vcHMobWRldik7CisKKwlpZiAob3BzLT5nZXRfZ2VuZXJhdGlvbikKKwkJcmV0 dXJuIG9wcy0+Z2V0X2dlbmVyYXRpb24obWRldik7CisKKwlyZXR1cm4gMDsKK30KKworc3RhdGlj IHU4IHZpcnRpb19tZGV2X2dldF9zdGF0dXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7 CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qg c3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMo bWRldik7CisKKwlyZXR1cm4gb3BzLT5nZXRfc3RhdHVzKG1kZXYpOworfQorCitzdGF0aWMgdm9p ZCB2aXJ0aW9fbWRldl9zZXRfc3RhdHVzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2LCB1OCBz dGF0dXMpCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7 CisJY29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3Zp cnRpb19vcHMobWRldik7CisKKwlyZXR1cm4gb3BzLT5zZXRfc3RhdHVzKG1kZXYsIHN0YXR1cyk7 Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3Jlc2V0KHN0cnVjdCB2aXJ0aW9fZGV2aWNl ICp2ZGV2KQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYp OworCWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92 aXJ0aW9fb3BzKG1kZXYpOworCisJcmV0dXJuIG9wcy0+c2V0X3N0YXR1cyhtZGV2LCAwKTsKK30K Kworc3RhdGljIGJvb2wgdmlydGlvX21kZXZfbm90aWZ5KHN0cnVjdCB2aXJ0cXVldWUgKnZxKQor eworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZxLT52ZGV2KTsKKwlj b25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlv X29wcyhtZGV2KTsKKworCW9wcy0+a2lja192cShtZGV2LCB2cS0+aW5kZXgpOworCisJcmV0dXJu IHRydWU7Cit9CisKK3N0YXRpYyBpcnFyZXR1cm5fdCB2aXJ0aW9fbWRldl9jb25maWdfY2Iodm9p ZCAqcHJpdmF0ZSkKK3sKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSBwcml2 YXRlOworCisJdmlydGlvX2NvbmZpZ19jaGFuZ2VkKCZ2bV9kZXYtPnZkZXYpOworCisJcmV0dXJu IElSUV9IQU5ETEVEOworfQorCitzdGF0aWMgaXJxcmV0dXJuX3QgdmlydGlvX21kZXZfdmlydHF1 ZXVlX2NiKHZvaWQgKnByaXZhdGUpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X3ZxX2luZm8gKmlu Zm8gPSBwcml2YXRlOworCisJcmV0dXJuIHZyaW5nX2ludGVycnVwdCgwLCBpbmZvLT52cSk7Cit9 CisKK3N0YXRpYyBzdHJ1Y3QgdmlydHF1ZXVlICoKK3ZpcnRpb19tZGV2X3NldHVwX3ZxKHN0cnVj dCB2aXJ0aW9fZGV2aWNlICp2ZGV2LCB1bnNpZ25lZCBpbnQgaW5kZXgsCisJCSAgICAgdm9pZCAo KmNhbGxiYWNrKShzdHJ1Y3QgdmlydHF1ZXVlICp2cSksCisJCSAgICAgY29uc3QgY2hhciAqbmFt ZSwgYm9vbCBjdHgpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0gdG9f dmlydGlvX21kZXZfZGV2aWNlKHZkZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZt X2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19kZXZpY2Vfb3BzICpv cHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCXN0cnVjdCB2aXJ0aW9fbWRldl92cV9p bmZvICppbmZvOworCXN0cnVjdCB2aXJ0aW9fbWRldl9jYWxsYmFjayBjYjsKKwlzdHJ1Y3Qgdmly dHF1ZXVlICp2cTsKKwl1NjQgZGVzY19hZGRyLCBkcml2ZXJfYWRkciwgZGV2aWNlX2FkZHI7CisJ dW5zaWduZWQgbG9uZyBmbGFnczsKKwl1MzIgYWxpZ24sIG51bTsKKwlpbnQgZXJyOworCisJaWYg KCFuYW1lKQorCQlyZXR1cm4gTlVMTDsKKworCS8qIFF1ZXVlIHNob3VsZG4ndCBhbHJlYWR5IGJl IHNldCB1cC4gKi8KKwlpZiAob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKQorCQlyZXR1 cm4gRVJSX1BUUigtRU5PRU5UKTsKKworCS8qIEFsbG9jYXRlIGFuZCBmaWxsIG91dCBvdXIgYWN0 aXZlIHF1ZXVlIGRlc2NyaXB0aW9uICovCisJaW5mbyA9IGttYWxsb2Moc2l6ZW9mKCppbmZvKSwg R0ZQX0tFUk5FTCk7CisJaWYgKCFpbmZvKQorCQlyZXR1cm4gRVJSX1BUUigtRU5PTUVNKTsKKwor CW51bSA9IG9wcy0+Z2V0X3ZxX251bV9tYXgobWRldik7CisJaWYgKG51bSA9PSAwKSB7CisJCWVy ciA9IC1FTk9FTlQ7CisJCWdvdG8gZXJyb3JfbmV3X3ZpcnRxdWV1ZTsKKwl9CisKKwkvKiBDcmVh dGUgdGhlIHZyaW5nICovCisJYWxpZ24gPSBvcHMtPmdldF92cV9hbGlnbihtZGV2KTsKKwl2cSA9 IHZyaW5nX2NyZWF0ZV92aXJ0cXVldWUoaW5kZXgsIG51bSwgYWxpZ24sIHZkZXYsCisJCQkJICAg IHRydWUsIHRydWUsIGN0eCwKKwkJCQkgICAgdmlydGlvX21kZXZfbm90aWZ5LCBjYWxsYmFjaywg bmFtZSk7CisJaWYgKCF2cSkgeworCQllcnIgPSAtRU5PTUVNOworCQlnb3RvIGVycm9yX25ld192 aXJ0cXVldWU7CisJfQorCisJLyogU2V0dXAgdmlydHF1ZXVlIGNhbGxiYWNrICovCisJY2IuY2Fs bGJhY2sgPSB2aXJ0aW9fbWRldl92aXJ0cXVldWVfY2I7CisJY2IucHJpdmF0ZSA9IGluZm87CisJ b3BzLT5zZXRfdnFfY2IobWRldiwgaW5kZXgsICZjYik7CisJb3BzLT5zZXRfdnFfbnVtKG1kZXYs IGluZGV4LCB2aXJ0cXVldWVfZ2V0X3ZyaW5nX3NpemUodnEpKTsKKworCWRlc2NfYWRkciA9IHZp cnRxdWV1ZV9nZXRfZGVzY19hZGRyKHZxKTsKKwlkcml2ZXJfYWRkciA9IHZpcnRxdWV1ZV9nZXRf YXZhaWxfYWRkcih2cSk7CisJZGV2aWNlX2FkZHIgPSB2aXJ0cXVldWVfZ2V0X3VzZWRfYWRkcih2 cSk7CisKKwlpZiAob3BzLT5zZXRfdnFfYWRkcmVzcyhtZGV2LCBpbmRleCwKKwkJCQlkZXNjX2Fk ZHIsIGRyaXZlcl9hZGRyLAorCQkJCWRldmljZV9hZGRyKSkgeworCQllcnIgPSAtRUlOVkFMOwor CQlnb3RvIGVycl92cTsKKwl9CisKKwlvcHMtPnNldF92cV9yZWFkeShtZGV2LCBpbmRleCwgMSk7 CisKKwl2cS0+cHJpdiA9IGluZm87CisJaW5mby0+dnEgPSB2cTsKKworCXNwaW5fbG9ja19pcnFz YXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2FkZCgmaW5mby0+bm9kZSwgJnZtX2Rl di0+dmlydHF1ZXVlcyk7CisJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmdm1fZGV2LT5sb2NrLCBm bGFncyk7CisKKwlyZXR1cm4gdnE7CisKK2Vycl92cToKKwl2cmluZ19kZWxfdmlydHF1ZXVlKHZx KTsKK2Vycm9yX25ld192aXJ0cXVldWU6CisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwgaW5kZXgs IDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKTsKKwlrZnJlZShp bmZvKTsKKwlyZXR1cm4gRVJSX1BUUihlcnIpOworfQorCitzdGF0aWMgdm9pZCB2aXJ0aW9fbWRl dl9kZWxfdnEoc3RydWN0IHZpcnRxdWV1ZSAqdnEpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2Rl dmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZxLT52ZGV2KTsKKwlzdHJ1Y3Qg bWRldl9kZXZpY2UgKm1kZXYgPSB2bV9kZXYtPm1kZXY7CisJY29uc3Qgc3RydWN0IG1kZXZfdmly dGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRldik7CisJc3RydWN0 IHZpcnRpb19tZGV2X3ZxX2luZm8gKmluZm8gPSB2cS0+cHJpdjsKKwl1bnNpZ25lZCBpbnQgaW5k ZXggPSB2cS0+aW5kZXg7CisJdW5zaWduZWQgbG9uZyBmbGFnczsKKworCXNwaW5fbG9ja19pcnFz YXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2RlbCgmaW5mby0+bm9kZSk7CisJc3Bp bl91bmxvY2tfaXJxcmVzdG9yZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisKKwkvKiBTZWxlY3Qg YW5kIGRlYWN0aXZhdGUgdGhlIHF1ZXVlICovCisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwgaW5k ZXgsIDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKTsKKworCXZy aW5nX2RlbF92aXJ0cXVldWUodnEpOworCisJa2ZyZWUoaW5mbyk7Cit9CisKK3N0YXRpYyB2b2lk IHZpcnRpb19tZGV2X2RlbF92cXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3Ry dWN0IHZpcnRxdWV1ZSAqdnEsICpuOworCisJbGlzdF9mb3JfZWFjaF9lbnRyeV9zYWZlKHZxLCBu LCAmdmRldi0+dnFzLCBsaXN0KQorCQl2aXJ0aW9fbWRldl9kZWxfdnEodnEpOworfQorCitzdGF0 aWMgaW50IHZpcnRpb19tZGV2X2ZpbmRfdnFzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2LCB1 bnNpZ25lZCBudnFzLAorCQkJCXN0cnVjdCB2aXJ0cXVldWUgKnZxc1tdLAorCQkJCXZxX2NhbGxi YWNrX3QgKmNhbGxiYWNrc1tdLAorCQkJCWNvbnN0IGNoYXIgKiBjb25zdCBuYW1lc1tdLAorCQkJ CWNvbnN0IGJvb2wgKmN0eCwKKwkJCQlzdHJ1Y3QgaXJxX2FmZmluaXR5ICpkZXNjKQoreworCXN0 cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2RldmljZSh2 ZGV2KTsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwlj b25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlv X29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfY2FsbGJhY2sgY2I7CisJaW50IGksIGVy ciwgcXVldWVfaWR4ID0gMDsKKworCWZvciAoaSA9IDA7IGkgPCBudnFzOyArK2kpIHsKKwkJaWYg KCFuYW1lc1tpXSkgeworCQkJdnFzW2ldID0gTlVMTDsKKwkJCWNvbnRpbnVlOworCQl9CisKKwkJ dnFzW2ldID0gdmlydGlvX21kZXZfc2V0dXBfdnEodmRldiwgcXVldWVfaWR4KyssCisJCQkJCSAg ICAgIGNhbGxiYWNrc1tpXSwgbmFtZXNbaV0sIGN0eCA/CisJCQkJCSAgICAgIGN0eFtpXSA6IGZh bHNlKTsKKwkJaWYgKElTX0VSUih2cXNbaV0pKSB7CisJCQllcnIgPSBQVFJfRVJSKHZxc1tpXSk7 CisJCQlnb3RvIGVycl9zZXR1cF92cTsKKwkJfQorCX0KKworCWNiLmNhbGxiYWNrID0gdmlydGlv X21kZXZfY29uZmlnX2NiOworCWNiLnByaXZhdGUgPSB2bV9kZXY7CisJb3BzLT5zZXRfY29uZmln X2NiKG1kZXYsICZjYik7CisKKwlyZXR1cm4gMDsKKworZXJyX3NldHVwX3ZxOgorCXZpcnRpb19t ZGV2X2RlbF92cXModmRldik7CisJcmV0dXJuIGVycjsKK30KKworc3RhdGljIHU2NCB2aXJ0aW9f bWRldl9nZXRfZmVhdHVyZXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3RydWN0 IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3RydWN0IG1k ZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRldik7CisK KwlyZXR1cm4gb3BzLT5nZXRfZmVhdHVyZXMobWRldik7Cit9CisKK3N0YXRpYyBpbnQgdmlydGlv X21kZXZfZmluYWxpemVfZmVhdHVyZXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJ c3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3Ry dWN0IG1kZXZfdmlydGlvX2RldmljZV9vcHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRl dik7CisKKwkvKiBHaXZlIHZpcnRpb19yaW5nIGEgY2hhbmNlIHRvIGFjY2VwdCBmZWF0dXJlcy4g Ki8KKwl2cmluZ190cmFuc3BvcnRfZmVhdHVyZXModmRldik7CisKKwlyZXR1cm4gb3BzLT5zZXRf ZmVhdHVyZXMobWRldiwgdmRldi0+ZmVhdHVyZXMpOworfQorCitzdGF0aWMgY29uc3QgY2hhciAq dmlydGlvX21kZXZfYnVzX25hbWUoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3Ry dWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZk ZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsKKworCXJldHVy biBkZXZfbmFtZShtZGV2X2RldihtZGV2KSk7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3Qgdmly dGlvX2NvbmZpZ19vcHMgdmlydGlvX21kZXZfY29uZmlnX29wcyA9IHsKKwkuZ2V0CQk9IHZpcnRp b19tZGV2X2dldCwKKwkuc2V0CQk9IHZpcnRpb19tZGV2X3NldCwKKwkuZ2VuZXJhdGlvbgk9IHZp cnRpb19tZGV2X2dlbmVyYXRpb24sCisJLmdldF9zdGF0dXMJPSB2aXJ0aW9fbWRldl9nZXRfc3Rh dHVzLAorCS5zZXRfc3RhdHVzCT0gdmlydGlvX21kZXZfc2V0X3N0YXR1cywKKwkucmVzZXQJCT0g dmlydGlvX21kZXZfcmVzZXQsCisJLmZpbmRfdnFzCT0gdmlydGlvX21kZXZfZmluZF92cXMsCisJ LmRlbF92cXMJPSB2aXJ0aW9fbWRldl9kZWxfdnFzLAorCS5nZXRfZmVhdHVyZXMJPSB2aXJ0aW9f bWRldl9nZXRfZmVhdHVyZXMsCisJLmZpbmFsaXplX2ZlYXR1cmVzID0gdmlydGlvX21kZXZfZmlu YWxpemVfZmVhdHVyZXMsCisJLmJ1c19uYW1lCT0gdmlydGlvX21kZXZfYnVzX25hbWUsCit9Owor CitzdGF0aWMgdm9pZCB2aXJ0aW9fbWRldl9yZWxlYXNlX2RldihzdHJ1Y3QgZGV2aWNlICpfZCkK K3sKKwlzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldiA9CisJICAgICAgIGNvbnRhaW5lcl9vZihf ZCwgc3RydWN0IHZpcnRpb19kZXZpY2UsIGRldik7CisJc3RydWN0IHZpcnRpb19tZGV2X2Rldmlj ZSAqdm1fZGV2ID0KKwkgICAgICAgY29udGFpbmVyX29mKHZkZXYsIHN0cnVjdCB2aXJ0aW9fbWRl dl9kZXZpY2UsIHZkZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRl djsKKworCWRldm1fa2ZyZWUobWRldl9kZXYobWRldiksIHZtX2Rldik7Cit9CisKK3N0YXRpYyBp bnQgdmlydGlvX21kZXZfcHJvYmUoc3RydWN0IGRldmljZSAqZGV2KQoreworCXN0cnVjdCBtZGV2 X2RldmljZSAqbWRldiA9IG1kZXZfZnJvbV9kZXYoZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92 aXJ0aW9fZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlvX29wcyhtZGV2KTsKKwlzdHJ1 Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXY7CisJaW50IHJjOworCisJdm1fZGV2ID0gZGV2 bV9remFsbG9jKGRldiwgc2l6ZW9mKCp2bV9kZXYpLCBHRlBfS0VSTkVMKTsKKwlpZiAoIXZtX2Rl dikKKwkJcmV0dXJuIC1FTk9NRU07CisKKwl2bV9kZXYtPnZkZXYuZGV2LnBhcmVudCA9IGRldjsK Kwl2bV9kZXYtPnZkZXYuZGV2LnJlbGVhc2UgPSB2aXJ0aW9fbWRldl9yZWxlYXNlX2RldjsKKwl2 bV9kZXYtPnZkZXYuY29uZmlnID0gJnZpcnRpb19tZGV2X2NvbmZpZ19vcHM7CisJdm1fZGV2LT5t ZGV2ID0gbWRldjsKKwlJTklUX0xJU1RfSEVBRCgmdm1fZGV2LT52aXJ0cXVldWVzKTsKKwlzcGlu X2xvY2tfaW5pdCgmdm1fZGV2LT5sb2NrKTsKKworCXZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPSBv cHMtPmdldF9kZXZpY2VfaWQobWRldik7CisJaWYgKHZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPT0g MCkKKwkJcmV0dXJuIC1FTk9ERVY7CisKKwl2bV9kZXYtPnZkZXYuaWQudmVuZG9yID0gb3BzLT5n ZXRfdmVuZG9yX2lkKG1kZXYpOworCXJjID0gcmVnaXN0ZXJfdmlydGlvX2RldmljZSgmdm1fZGV2 LT52ZGV2KTsKKwlpZiAocmMpCisJCXB1dF9kZXZpY2UoZGV2KTsKKwllbHNlCisJCWRldl9zZXRf ZHJ2ZGF0YShkZXYsIHZtX2Rldik7CisKKwlyZXR1cm4gcmM7Cit9CisKK3N0YXRpYyB2b2lkIHZp cnRpb19tZGV2X3JlbW92ZShzdHJ1Y3QgZGV2aWNlICpkZXYpCit7CisJc3RydWN0IHZpcnRpb19t ZGV2X2RldmljZSAqdm1fZGV2ID0gZGV2X2dldF9kcnZkYXRhKGRldik7CisKKwl1bnJlZ2lzdGVy X3ZpcnRpb19kZXZpY2UoJnZtX2Rldi0+dmRldik7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3Qg bWRldl9jbGFzc19pZCB2aXJ0aW9faWRfdGFibGVbXSA9IHsKKwl7IE1ERVZfQ0xBU1NfSURfVklS VElPIH0sCisJeyAwIH0sCit9OworCitNT0RVTEVfREVWSUNFX1RBQkxFKG1kZXYsIHZpcnRpb19p ZF90YWJsZSk7CisKK3N0YXRpYyBzdHJ1Y3QgbWRldl9kcml2ZXIgdmlydGlvX21kZXZfZHJpdmVy ID0geworCS5uYW1lCT0gInZpcnRpb19tZGV2IiwKKwkucHJvYmUJPSB2aXJ0aW9fbWRldl9wcm9i ZSwKKwkucmVtb3ZlID0gdmlydGlvX21kZXZfcmVtb3ZlLAorCS5pZF90YWJsZSA9IHZpcnRpb19p ZF90YWJsZSwKK307CisKK3N0YXRpYyBpbnQgX19pbml0IHZpcnRpb19tZGV2X2luaXQodm9pZCkK K3sKKwlyZXR1cm4gbWRldl9yZWdpc3Rlcl9kcml2ZXIoJnZpcnRpb19tZGV2X2RyaXZlciwgVEhJ U19NT0RVTEUpOworfQorCitzdGF0aWMgdm9pZCBfX2V4aXQgdmlydGlvX21kZXZfZXhpdCh2b2lk KQoreworCW1kZXZfdW5yZWdpc3Rlcl9kcml2ZXIoJnZpcnRpb19tZGV2X2RyaXZlcik7Cit9CisK K21vZHVsZV9pbml0KHZpcnRpb19tZGV2X2luaXQpCittb2R1bGVfZXhpdCh2aXJ0aW9fbWRldl9l eGl0KQorCitNT0RVTEVfVkVSU0lPTihEUklWRVJfVkVSU0lPTik7CitNT0RVTEVfTElDRU5TRSgi R1BMIHYyIik7CitNT0RVTEVfQVVUSE9SKERSSVZFUl9BVVRIT1IpOworTU9EVUxFX0RFU0NSSVBU SU9OKERSSVZFUl9ERVNDKTsKLS0gCjIuMTkuMQoKX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX18KSW50ZWwtZ2Z4IG1haWxpbmcgbGlzdApJbnRlbC1nZnhAbGlz dHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBzOi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4v bGlzdGluZm8vaW50ZWwtZ2Z4