From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jason Wang Subject: [PATCH V5 5/6] virtio: introduce a mdev based transport Date: Wed, 23 Oct 2019 21:07:51 +0800 Message-ID: <20191023130752.18980-6-jasowang@redhat.com> References: <20191023130752.18980-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: <20191023130752.18980-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: intel-gfx@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 device specific ops which is a part of mdev_parent_ops now. Signed-off-by: Jason Wang --- drivers/virtio/Kconfig | 7 + drivers/virtio/Makefile | 1 + drivers/virtio/virtio_mdev.c | 413 +++++++++++++++++++++++++++++++++++ 3 files changed, 421 insertions(+) create mode 100644 drivers/virtio/virtio_mdev.c diff --git a/drivers/virtio/Kconfig b/drivers/virtio/Kconfig index 078615cf2afc..8d18722ab572 100644 --- a/drivers/virtio/Kconfig +++ b/drivers/virtio/Kconfig @@ -43,6 +43,13 @@ config VIRTIO_PCI_LEGACY =20 =09 If unsure, say Y. =20 +config VIRTIO_MDEV_DEVICE +=09tristate "VIRTIO driver for Mediated devices" +=09depends on VFIO_MDEV && VIRTIO +=09default n +=09help +=09 VIRTIO based driver for Mediated devices. + config VIRTIO_PMEM =09tristate "Support for virtio pmem driver" =09depends on VIRTIO diff --git a/drivers/virtio/Makefile b/drivers/virtio/Makefile index 3a2b5c5dcf46..ebc7fa15ae82 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_DEVICE) +=3D virtio_mdev.o diff --git a/drivers/virtio/virtio_mdev.c b/drivers/virtio/virtio_mdev.c new file mode 100644 index 000000000000..eb2621f9182c --- /dev/null +++ b/drivers/virtio/virtio_mdev.c @@ -0,0 +1,413 @@ +// 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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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 virtio_mdev_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->features =3D ops->get_mdev_features(mdev); +=09if (vm_dev->features !=3D VIRTIO_MDEV_F_VERSION_1) { +=09=09dev_err(dev, "VIRTIO_MDEV_F_VERSION_1 is mandatory\n"); +=09=09return -ENXIO; +=09} + +=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 id_table[] =3D { +=09{ MDEV_CLASS_ID_VIRTIO }, +=09{ 0 }, +}; + +MODULE_DEVICE_TABLE(mdev, 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 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.7 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED 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 C1690C47E49 for ; Wed, 23 Oct 2019 13:25:41 +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 998C521925 for ; Wed, 23 Oct 2019 13:25:41 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 998C521925 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 2BA136EAAF; Wed, 23 Oct 2019 13:25:41 +0000 (UTC) Received: from us-smtp-1.mimecast.com (us-smtp-delivery-1.mimecast.com [207.211.31.120]) by gabe.freedesktop.org (Postfix) with ESMTPS id CC25689F69 for ; Wed, 23 Oct 2019 13:25:39 +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-245-Dyv3XFIFMNyzKYl-olh4-Q-1; Wed, 23 Oct 2019 09:25:35 -0400 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 5B176100551D; Wed, 23 Oct 2019 13:25:31 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-126.pek2.redhat.com [10.72.12.126]) by smtp.corp.redhat.com (Postfix) with ESMTP id 474626012E; Wed, 23 Oct 2019 13:23:32 +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, 23 Oct 2019 21:07:51 +0800 Message-Id: <20191023130752.18980-6-jasowang@redhat.com> In-Reply-To: <20191023130752.18980-1-jasowang@redhat.com> References: <20191023130752.18980-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-MC-Unique: Dyv3XFIFMNyzKYl-olh4-Q-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=1571837138; 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=aCX3HRqM2gF1Momqf/VdInXEsm+G0x9On2AZGQWmCoc=; b=f5eCbCIi3H+pNDU7Mq0u9vVHXi9h2kkLUzfomBqPIFPhC65A0ubNRo9QxPDgMFTTIth3Bd eNV55EOvBjwEfCJiWFoqVgMW8SLqQasmTXtQz7F8CVeIrK6mVyx/QuZOid27Ks+slLT7MF QpPB1Rznmlco+MKPVfegRczxbBZwsUo= Subject: [Intel-gfx] [PATCH V5 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: <20191023130751.XEjpsiKbf6QoNRaRNuq1RsA1ITrp1F22dbgDu7yTu6k@z> VGhpcyBwYXRjaCBpbnRyb2R1Y2VzIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZvciB2aXJ0aW8uIFRo aXMgaXMgdXNlZCB0bwp1c2Uga2VybmVsIHZpcnRpbyBkcml2ZXIgdG8gZHJpdmUgdGhlIG1lZGlh dGVkIGRldmljZSB0aGF0IGlzIGNhcGFibGUKb2YgcG9wdWxhdGluZyB2aXJ0cXVldWUgZGlyZWN0 bHkuCgpBIG5ldyB2aXJ0aW8tbWRldiBkcml2ZXIgd2lsbCBiZSByZWdpc3RlcmVkIHRvIHRoZSBt ZGV2IGJ1cywgd2hlbiBhCm5ldyB2aXJ0aW8tbWRldiBkZXZpY2UgaXMgcHJvYmVkLCBpdCB3aWxs IHJlZ2lzdGVyIHRoZSBkZXZpY2Ugd2l0aAptZGV2IGJhc2VkIGNvbmZpZyBvcHMuIFRoaXMgbWVh bnMgaXQgaXMgYSBzb2Z0d2FyZSB0cmFuc3BvcnQgYmV0d2VlbgptZGV2IGRyaXZlciBhbmQgbWRl diBkZXZpY2UuIFRoZSB0cmFuc3BvcnQgd2FzIGltcGxlbWVudGVkIHRocm91Z2gKZGV2aWNlIHNw ZWNpZmljIG9wcyB3aGljaCBpcyBhIHBhcnQgb2YgbWRldl9wYXJlbnRfb3BzIG5vdy4KClNpZ25l ZC1vZmYtYnk6IEphc29uIFdhbmcgPGphc293YW5nQHJlZGhhdC5jb20+Ci0tLQogZHJpdmVycy92 aXJ0aW8vS2NvbmZpZyAgICAgICB8ICAgNyArCiBkcml2ZXJzL3ZpcnRpby9NYWtlZmlsZSAgICAg IHwgICAxICsKIGRyaXZlcnMvdmlydGlvL3ZpcnRpb19tZGV2LmMgfCA0MTMgKysrKysrKysrKysr KysrKysrKysrKysrKysrKysrKysrKysKIDMgZmlsZXMgY2hhbmdlZCwgNDIxIGluc2VydGlvbnMo KykKIGNyZWF0ZSBtb2RlIDEwMDY0NCBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jCgpkaWZm IC0tZ2l0IGEvZHJpdmVycy92aXJ0aW8vS2NvbmZpZyBiL2RyaXZlcnMvdmlydGlvL0tjb25maWcK aW5kZXggMDc4NjE1Y2YyYWZjLi44ZDE4NzIyYWI1NzIgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvdmly dGlvL0tjb25maWcKKysrIGIvZHJpdmVycy92aXJ0aW8vS2NvbmZpZwpAQCAtNDMsNiArNDMsMTMg QEAgY29uZmlnIFZJUlRJT19QQ0lfTEVHQUNZCiAKIAkgIElmIHVuc3VyZSwgc2F5IFkuCiAKK2Nv bmZpZyBWSVJUSU9fTURFVl9ERVZJQ0UKKwl0cmlzdGF0ZSAiVklSVElPIGRyaXZlciBmb3IgTWVk aWF0ZWQgZGV2aWNlcyIKKwlkZXBlbmRzIG9uIFZGSU9fTURFViAmJiBWSVJUSU8KKwlkZWZhdWx0 IG4KKwloZWxwCisJICBWSVJUSU8gYmFzZWQgZHJpdmVyIGZvciBNZWRpYXRlZCBkZXZpY2VzLgor CiBjb25maWcgVklSVElPX1BNRU0KIAl0cmlzdGF0ZSAiU3VwcG9ydCBmb3IgdmlydGlvIHBtZW0g ZHJpdmVyIgogCWRlcGVuZHMgb24gVklSVElPCmRpZmYgLS1naXQgYS9kcml2ZXJzL3ZpcnRpby9N YWtlZmlsZSBiL2RyaXZlcnMvdmlydGlvL01ha2VmaWxlCmluZGV4IDNhMmI1YzVkY2Y0Ni4uZWJj N2ZhMTVhZTgyIDEwMDY0NAotLS0gYS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZQorKysgYi9kcml2 ZXJzL3ZpcnRpby9NYWtlZmlsZQpAQCAtNiwzICs2LDQgQEAgdmlydGlvX3BjaS15IDo9IHZpcnRp b19wY2lfbW9kZXJuLm8gdmlydGlvX3BjaV9jb21tb24ubwogdmlydGlvX3BjaS0kKENPTkZJR19W SVJUSU9fUENJX0xFR0FDWSkgKz0gdmlydGlvX3BjaV9sZWdhY3kubwogb2JqLSQoQ09ORklHX1ZJ UlRJT19CQUxMT09OKSArPSB2aXJ0aW9fYmFsbG9vbi5vCiBvYmotJChDT05GSUdfVklSVElPX0lO UFVUKSArPSB2aXJ0aW9faW5wdXQubworb2JqLSQoQ09ORklHX1ZJUlRJT19NREVWX0RFVklDRSkg Kz0gdmlydGlvX21kZXYubwpkaWZmIC0tZ2l0IGEvZHJpdmVycy92aXJ0aW8vdmlydGlvX21kZXYu YyBiL2RyaXZlcnMvdmlydGlvL3ZpcnRpb19tZGV2LmMKbmV3IGZpbGUgbW9kZSAxMDA2NDQKaW5k ZXggMDAwMDAwMDAwMDAwLi5lYjI2MjFmOTE4MmMKLS0tIC9kZXYvbnVsbAorKysgYi9kcml2ZXJz L3ZpcnRpby92aXJ0aW9fbWRldi5jCkBAIC0wLDAgKzEsNDEzIEBACisvLyBTUERYLUxpY2Vuc2Ut SWRlbnRpZmllcjogR1BMLTIuMC1vbmx5CisvKgorICogVklSVElPIGJhc2VkIGRyaXZlciBmb3Ig TWVkaWF0ZWQgZGV2aWNlCisgKgorICogQ29weXJpZ2h0IChjKSAyMDE5LCBSZWQgSGF0LiBBbGwg cmlnaHRzIHJlc2VydmVkLgorICogICAgIEF1dGhvcjogSmFzb24gV2FuZyA8amFzb3dhbmdAcmVk aGF0LmNvbT4KKyAqCisgKi8KKworI2luY2x1ZGUgPGxpbnV4L2luaXQuaD4KKyNpbmNsdWRlIDxs aW51eC9tb2R1bGUuaD4KKyNpbmNsdWRlIDxsaW51eC9kZXZpY2UuaD4KKyNpbmNsdWRlIDxsaW51 eC9rZXJuZWwuaD4KKyNpbmNsdWRlIDxsaW51eC9zbGFiLmg+CisjaW5jbHVkZSA8bGludXgvdXVp ZC5oPgorI2luY2x1ZGUgPGxpbnV4L21kZXYuaD4KKyNpbmNsdWRlIDxsaW51eC92aXJ0aW9fbWRl dl9vcHMuaD4KKyNpbmNsdWRlIDxsaW51eC92aXJ0aW8uaD4KKyNpbmNsdWRlIDxsaW51eC92aXJ0 aW9fY29uZmlnLmg+CisjaW5jbHVkZSA8bGludXgvdmlydGlvX3JpbmcuaD4KKworI2RlZmluZSBE UklWRVJfVkVSU0lPTiAgIjAuMSIKKyNkZWZpbmUgRFJJVkVSX0FVVEhPUiAgICJSZWQgSGF0IENv cnBvcmF0aW9uIgorI2RlZmluZSBEUklWRVJfREVTQyAgICAgIlZJUlRJTyBiYXNlZCBkcml2ZXIg Zm9yIE1lZGlhdGVkIGRldmljZSIKKworI2RlZmluZSB0b192aXJ0aW9fbWRldl9kZXZpY2UoZGV2 KSBcCisJY29udGFpbmVyX29mKGRldiwgc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSwgdmRldikK Kworc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSB7CisJc3RydWN0IHZpcnRpb19kZXZpY2UgdmRl djsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXY7CisJdTY0IGZlYXR1cmVzOworCisJLyogVGhl IGxvY2sgdG8gcHJvdGVjdCB2aXJ0cXVldWUgbGlzdCAqLworCXNwaW5sb2NrX3QgbG9jazsKKwkv KiBMaXN0IG9mIHZpcnRpb19tZGV2X3ZxX2luZm8gKi8KKwlzdHJ1Y3QgbGlzdF9oZWFkIHZpcnRx dWV1ZXM7Cit9OworCitzdHJ1Y3QgdmlydGlvX21kZXZfdnFfaW5mbyB7CisJLyogdGhlIGFjdHVh bCB2aXJ0cXVldWUgKi8KKwlzdHJ1Y3QgdmlydHF1ZXVlICp2cTsKKworCS8qIHRoZSBsaXN0IG5v ZGUgZm9yIHRoZSB2aXJ0cXVldWVzIGxpc3QgKi8KKwlzdHJ1Y3QgbGlzdF9oZWFkIG5vZGU7Cit9 OworCitzdGF0aWMgc3RydWN0IG1kZXZfZGV2aWNlICp2bV9nZXRfbWRldihzdHJ1Y3QgdmlydGlv X2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSB0 b192aXJ0aW9fbWRldl9kZXZpY2UodmRldik7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0g dm1fZGV2LT5tZGV2OworCisJcmV0dXJuIG1kZXY7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19t ZGV2X2dldChzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJ ICAgIHZvaWQgKmJ1ZiwgdW5zaWduZWQgbGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRl diA9IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2Vf b3BzICpvcHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCisJb3BzLT5nZXRfY29uZmln KG1kZXYsIG9mZnNldCwgYnVmLCBsZW4pOworfQorCitzdGF0aWMgdm9pZCB2aXJ0aW9fbWRldl9z ZXQoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYsIHVuc2lnbmVkIG9mZnNldCwKKwkJCSAgICBj b25zdCB2b2lkICpidWYsIHVuc2lnbmVkIGxlbikKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1k ZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNl X29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlvX29wcyhtZGV2KTsKKworCW9wcy0+c2V0X2NvbmZp ZyhtZGV2LCBvZmZzZXQsIGJ1ZiwgbGVuKTsKK30KKworc3RhdGljIHUzMiB2aXJ0aW9fbWRldl9n ZW5lcmF0aW9uKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2KQoreworCXN0cnVjdCBtZGV2X2Rl dmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCB2aXJ0aW9fbWRl dl9kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCisJaWYgKG9w cy0+Z2V0X2dlbmVyYXRpb24pCisJCXJldHVybiBvcHMtPmdldF9nZW5lcmF0aW9uKG1kZXYpOwor CisJcmV0dXJuIDA7Cit9CisKK3N0YXRpYyB1OCB2aXJ0aW9fbWRldl9nZXRfc3RhdHVzKHN0cnVj dCB2aXJ0aW9fZGV2aWNlICp2ZGV2KQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZt X2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2Vfb3BzICpv cHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCisJcmV0dXJuIG9wcy0+Z2V0X3N0YXR1 cyhtZGV2KTsKK30KKworc3RhdGljIHZvaWQgdmlydGlvX21kZXZfc2V0X3N0YXR1cyhzdHJ1Y3Qg dmlydGlvX2RldmljZSAqdmRldiwgdTggc3RhdHVzKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAq bWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZp Y2Vfb3BzICpvcHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCisJcmV0dXJuIG9wcy0+ c2V0X3N0YXR1cyhtZGV2LCBzdGF0dXMpOworfQorCitzdGF0aWMgdm9pZCB2aXJ0aW9fbWRldl9y ZXNldChzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2Ug Km1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmlydGlvX29wcyhtZGV2KTsKKworCXJldHVybiBvcHMt PnNldF9zdGF0dXMobWRldiwgMCk7Cit9CisKK3N0YXRpYyBib29sIHZpcnRpb19tZGV2X25vdGlm eShzdHJ1Y3QgdmlydHF1ZXVlICp2cSkKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2 bV9nZXRfbWRldih2cS0+dmRldik7CisJY29uc3Qgc3RydWN0IHZpcnRpb19tZGV2X2RldmljZV9v cHMgKm9wcyA9IG1kZXZfZ2V0X3ZpcnRpb19vcHMobWRldik7CisKKwlvcHMtPmtpY2tfdnEobWRl diwgdnEtPmluZGV4KTsKKworCXJldHVybiB0cnVlOworfQorCitzdGF0aWMgaXJxcmV0dXJuX3Qg dmlydGlvX21kZXZfY29uZmlnX2NiKHZvaWQgKnByaXZhdGUpCit7CisJc3RydWN0IHZpcnRpb19t ZGV2X2RldmljZSAqdm1fZGV2ID0gcHJpdmF0ZTsKKworCXZpcnRpb19jb25maWdfY2hhbmdlZCgm dm1fZGV2LT52ZGV2KTsKKworCXJldHVybiBJUlFfSEFORExFRDsKK30KKworc3RhdGljIGlycXJl dHVybl90IHZpcnRpb19tZGV2X3ZpcnRxdWV1ZV9jYih2b2lkICpwcml2YXRlKQoreworCXN0cnVj dCB2aXJ0aW9fbWRldl92cV9pbmZvICppbmZvID0gcHJpdmF0ZTsKKworCXJldHVybiB2cmluZ19p bnRlcnJ1cHQoMCwgaW5mby0+dnEpOworfQorCitzdGF0aWMgc3RydWN0IHZpcnRxdWV1ZSAqCit2 aXJ0aW9fbWRldl9zZXR1cF92cShzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldiwgdW5zaWduZWQg aW5kZXgsCisJCSAgICAgdm9pZCAoKmNhbGxiYWNrKShzdHJ1Y3QgdmlydHF1ZXVlICp2cSksCisJ CSAgICAgY29uc3QgY2hhciAqbmFtZSwgYm9vbCBjdHgpCit7CisJc3RydWN0IHZpcnRpb19tZGV2 X2RldmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZkZXYpOworCXN0cnVjdCBt ZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCB2aXJ0 aW9fbWRldl9kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCXN0 cnVjdCB2aXJ0aW9fbWRldl92cV9pbmZvICppbmZvOworCXN0cnVjdCB2aXJ0aW9fbWRldl9jYWxs YmFjayBjYjsKKwlzdHJ1Y3QgdmlydHF1ZXVlICp2cTsKKwl1NjQgZGVzY19hZGRyLCBkcml2ZXJf YWRkciwgZGV2aWNlX2FkZHI7CisJdW5zaWduZWQgbG9uZyBmbGFnczsKKwl1MzIgYWxpZ24sIG51 bTsKKwlpbnQgZXJyOworCisJaWYgKCFuYW1lKQorCQlyZXR1cm4gTlVMTDsKKworCS8qIFF1ZXVl IHNob3VsZG4ndCBhbHJlYWR5IGJlIHNldCB1cC4gKi8KKwlpZiAob3BzLT5nZXRfdnFfcmVhZHko bWRldiwgaW5kZXgpKQorCQlyZXR1cm4gRVJSX1BUUigtRU5PRU5UKTsKKworCS8qIEFsbG9jYXRl IGFuZCBmaWxsIG91dCBvdXIgYWN0aXZlIHF1ZXVlIGRlc2NyaXB0aW9uICovCisJaW5mbyA9IGtt YWxsb2Moc2l6ZW9mKCppbmZvKSwgR0ZQX0tFUk5FTCk7CisJaWYgKCFpbmZvKQorCQlyZXR1cm4g RVJSX1BUUigtRU5PTUVNKTsKKworCW51bSA9IG9wcy0+Z2V0X3ZxX251bV9tYXgobWRldik7CisJ aWYgKG51bSA9PSAwKSB7CisJCWVyciA9IC1FTk9FTlQ7CisJCWdvdG8gZXJyb3JfbmV3X3ZpcnRx dWV1ZTsKKwl9CisKKwkvKiBDcmVhdGUgdGhlIHZyaW5nICovCisJYWxpZ24gPSBvcHMtPmdldF92 cV9hbGlnbihtZGV2KTsKKwl2cSA9IHZyaW5nX2NyZWF0ZV92aXJ0cXVldWUoaW5kZXgsIG51bSwg YWxpZ24sIHZkZXYsCisJCQkJICAgIHRydWUsIHRydWUsIGN0eCwKKwkJCQkgICAgdmlydGlvX21k ZXZfbm90aWZ5LCBjYWxsYmFjaywgbmFtZSk7CisJaWYgKCF2cSkgeworCQllcnIgPSAtRU5PTUVN OworCQlnb3RvIGVycm9yX25ld192aXJ0cXVldWU7CisJfQorCisJLyogU2V0dXAgdmlydHF1ZXVl IGNhbGxiYWNrICovCisJY2IuY2FsbGJhY2sgPSB2aXJ0aW9fbWRldl92aXJ0cXVldWVfY2I7CisJ Y2IucHJpdmF0ZSA9IGluZm87CisJb3BzLT5zZXRfdnFfY2IobWRldiwgaW5kZXgsICZjYik7CisJ b3BzLT5zZXRfdnFfbnVtKG1kZXYsIGluZGV4LCB2aXJ0cXVldWVfZ2V0X3ZyaW5nX3NpemUodnEp KTsKKworCWRlc2NfYWRkciA9IHZpcnRxdWV1ZV9nZXRfZGVzY19hZGRyKHZxKTsKKwlkcml2ZXJf YWRkciA9IHZpcnRxdWV1ZV9nZXRfYXZhaWxfYWRkcih2cSk7CisJZGV2aWNlX2FkZHIgPSB2aXJ0 cXVldWVfZ2V0X3VzZWRfYWRkcih2cSk7CisKKwlpZiAob3BzLT5zZXRfdnFfYWRkcmVzcyhtZGV2 LCBpbmRleCwKKwkJCQlkZXNjX2FkZHIsIGRyaXZlcl9hZGRyLAorCQkJCWRldmljZV9hZGRyKSkg eworCQllcnIgPSAtRUlOVkFMOworCQlnb3RvIGVycl92cTsKKwl9CisKKwlvcHMtPnNldF92cV9y ZWFkeShtZGV2LCBpbmRleCwgMSk7CisKKwl2cS0+cHJpdiA9IGluZm87CisJaW5mby0+dnEgPSB2 cTsKKworCXNwaW5fbG9ja19pcnFzYXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2Fk ZCgmaW5mby0+bm9kZSwgJnZtX2Rldi0+dmlydHF1ZXVlcyk7CisJc3Bpbl91bmxvY2tfaXJxcmVz dG9yZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisKKwlyZXR1cm4gdnE7CisKK2Vycl92cToKKwl2 cmluZ19kZWxfdmlydHF1ZXVlKHZxKTsKK2Vycm9yX25ld192aXJ0cXVldWU6CisJb3BzLT5zZXRf dnFfcmVhZHkobWRldiwgaW5kZXgsIDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRl diwgaW5kZXgpKTsKKwlrZnJlZShpbmZvKTsKKwlyZXR1cm4gRVJSX1BUUihlcnIpOworCit9CisK K3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X2RlbF92cShzdHJ1Y3QgdmlydHF1ZXVlICp2cSkKK3sK KwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSB0b192aXJ0aW9fbWRldl9kZXZp Y2UodnEtPnZkZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsK Kwljb25zdCBzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlX29wcyAqb3BzID0gbWRldl9nZXRfdmly dGlvX29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfdnFfaW5mbyAqaW5mbyA9IHZxLT5w cml2OworCXVuc2lnbmVkIGludCBpbmRleCA9IHZxLT5pbmRleDsKKwl1bnNpZ25lZCBsb25nIGZs YWdzOworCisJc3Bpbl9sb2NrX2lycXNhdmUoJnZtX2Rldi0+bG9jaywgZmxhZ3MpOworCWxpc3Rf ZGVsKCZpbmZvLT5ub2RlKTsKKwlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZ2bV9kZXYtPmxvY2ss IGZsYWdzKTsKKworCS8qIFNlbGVjdCBhbmQgZGVhY3RpdmF0ZSB0aGUgcXVldWUgKi8KKwlvcHMt PnNldF92cV9yZWFkeShtZGV2LCBpbmRleCwgMCk7CisJV0FSTl9PTihvcHMtPmdldF92cV9yZWFk eShtZGV2LCBpbmRleCkpOworCisJdnJpbmdfZGVsX3ZpcnRxdWV1ZSh2cSk7CisKKwlrZnJlZShp bmZvKTsKK30KKworc3RhdGljIHZvaWQgdmlydGlvX21kZXZfZGVsX3ZxcyhzdHJ1Y3QgdmlydGlv X2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgdmlydHF1ZXVlICp2cSwgKm47CisKKwlsaXN0X2Zv cl9lYWNoX2VudHJ5X3NhZmUodnEsIG4sICZ2ZGV2LT52cXMsIGxpc3QpCisJCXZpcnRpb19tZGV2 X2RlbF92cSh2cSk7Cit9CisKK3N0YXRpYyBpbnQgdmlydGlvX21kZXZfZmluZF92cXMoc3RydWN0 IHZpcnRpb19kZXZpY2UgKnZkZXYsIHVuc2lnbmVkIG52cXMsCisJCQkJc3RydWN0IHZpcnRxdWV1 ZSAqdnFzW10sCisJCQkJdnFfY2FsbGJhY2tfdCAqY2FsbGJhY2tzW10sCisJCQkJY29uc3QgY2hh ciAqIGNvbnN0IG5hbWVzW10sCisJCQkJY29uc3QgYm9vbCAqY3R4LAorCQkJCXN0cnVjdCBpcnFf YWZmaW5pdHkgKmRlc2MpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0g dG9fdmlydGlvX21kZXZfZGV2aWNlKHZkZXYpOworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9 IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2Vfb3Bz ICpvcHMgPSBtZGV2X2dldF92aXJ0aW9fb3BzKG1kZXYpOworCXN0cnVjdCB2aXJ0aW9fbWRldl9j YWxsYmFjayBjYjsKKwlpbnQgaSwgZXJyLCBxdWV1ZV9pZHggPSAwOworCisJZm9yIChpID0gMDsg aSA8IG52cXM7ICsraSkgeworCQlpZiAoIW5hbWVzW2ldKSB7CisJCQl2cXNbaV0gPSBOVUxMOwor CQkJY29udGludWU7CisJCX0KKworCQl2cXNbaV0gPSB2aXJ0aW9fbWRldl9zZXR1cF92cSh2ZGV2 LCBxdWV1ZV9pZHgrKywKKwkJCQkJICAgICAgY2FsbGJhY2tzW2ldLCBuYW1lc1tpXSwgY3R4ID8K KwkJCQkJICAgICAgY3R4W2ldIDogZmFsc2UpOworCQlpZiAoSVNfRVJSKHZxc1tpXSkpIHsKKwkJ CWVyciA9IFBUUl9FUlIodnFzW2ldKTsKKwkJCWdvdG8gZXJyX3NldHVwX3ZxOworCQl9CisJfQor CisJY2IuY2FsbGJhY2sgPSB2aXJ0aW9fbWRldl9jb25maWdfY2I7CisJY2IucHJpdmF0ZSA9IHZt X2RldjsKKwlvcHMtPnNldF9jb25maWdfY2IobWRldiwgJmNiKTsKKworCXJldHVybiAwOworCitl cnJfc2V0dXBfdnE6CisJdmlydGlvX21kZXZfZGVsX3Zxcyh2ZGV2KTsKKwlyZXR1cm4gZXJyOwor fQorCitzdGF0aWMgdTY0IHZpcnRpb19tZGV2X2dldF9mZWF0dXJlcyhzdHJ1Y3QgdmlydGlvX2Rl dmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2 ZGV2KTsKKwljb25zdCBzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlX29wcyAqb3BzID0gbWRldl9n ZXRfdmlydGlvX29wcyhtZGV2KTsKKworCXJldHVybiBvcHMtPmdldF9mZWF0dXJlcyhtZGV2KTsK K30KKworc3RhdGljIGludCB2aXJ0aW9fbWRldl9maW5hbGl6ZV9mZWF0dXJlcyhzdHJ1Y3Qgdmly dGlvX2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRf bWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlX29wcyAqb3BzID0g bWRldl9nZXRfdmlydGlvX29wcyhtZGV2KTsKKworCS8qIEdpdmUgdmlydGlvX3JpbmcgYSBjaGFu Y2UgdG8gYWNjZXB0IGZlYXR1cmVzLiAqLworCXZyaW5nX3RyYW5zcG9ydF9mZWF0dXJlcyh2ZGV2 KTsKKworCXJldHVybiBvcHMtPnNldF9mZWF0dXJlcyhtZGV2LCB2ZGV2LT5mZWF0dXJlcyk7Cit9 CisKK3N0YXRpYyBjb25zdCBjaGFyICp2aXJ0aW9fbWRldl9idXNfbmFtZShzdHJ1Y3QgdmlydGlv X2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSB0 b192aXJ0aW9fbWRldl9kZXZpY2UodmRldik7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0g dm1fZGV2LT5tZGV2OworCisJcmV0dXJuIGRldl9uYW1lKG1kZXZfZGV2KG1kZXYpKTsKK30KKwor c3RhdGljIGNvbnN0IHN0cnVjdCB2aXJ0aW9fY29uZmlnX29wcyB2aXJ0aW9fbWRldl9jb25maWdf b3BzID0geworCS5nZXQJCT0gdmlydGlvX21kZXZfZ2V0LAorCS5zZXQJCT0gdmlydGlvX21kZXZf c2V0LAorCS5nZW5lcmF0aW9uCT0gdmlydGlvX21kZXZfZ2VuZXJhdGlvbiwKKwkuZ2V0X3N0YXR1 cwk9IHZpcnRpb19tZGV2X2dldF9zdGF0dXMsCisJLnNldF9zdGF0dXMJPSB2aXJ0aW9fbWRldl9z ZXRfc3RhdHVzLAorCS5yZXNldAkJPSB2aXJ0aW9fbWRldl9yZXNldCwKKwkuZmluZF92cXMJPSB2 aXJ0aW9fbWRldl9maW5kX3ZxcywKKwkuZGVsX3Zxcwk9IHZpcnRpb19tZGV2X2RlbF92cXMsCisJ LmdldF9mZWF0dXJlcwk9IHZpcnRpb19tZGV2X2dldF9mZWF0dXJlcywKKwkuZmluYWxpemVfZmVh dHVyZXMgPSB2aXJ0aW9fbWRldl9maW5hbGl6ZV9mZWF0dXJlcywKKwkuYnVzX25hbWUJPSB2aXJ0 aW9fbWRldl9idXNfbmFtZSwKK307CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3JlbGVhc2Vf ZGV2KHN0cnVjdCBkZXZpY2UgKl9kKQoreworCXN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2ID0K KwkgICAgICAgY29udGFpbmVyX29mKF9kLCBzdHJ1Y3QgdmlydGlvX2RldmljZSwgZGV2KTsKKwlz dHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPQorCSAgICAgICBjb250YWluZXJfb2Yo dmRldiwgc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSwgdmRldik7CisJc3RydWN0IG1kZXZfZGV2 aWNlICptZGV2ID0gdm1fZGV2LT5tZGV2OworCisJZGV2bV9rZnJlZShtZGV2X2RldihtZGV2KSwg dm1fZGV2KTsKK30KKworc3RhdGljIGludCB2aXJ0aW9fbWRldl9wcm9iZShzdHJ1Y3QgZGV2aWNl ICpkZXYpCit7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gbWRldl9mcm9tX2RldihkZXYp OworCWNvbnN0IHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2Vfb3BzICpvcHMgPSBtZGV2X2dldF92 aXJ0aW9fb3BzKG1kZXYpOworCXN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldjsKKwlp bnQgcmM7CisKKwl2bV9kZXYgPSBkZXZtX2t6YWxsb2MoZGV2LCBzaXplb2YoKnZtX2RldiksIEdG UF9LRVJORUwpOworCWlmICghdm1fZGV2KQorCQlyZXR1cm4gLUVOT01FTTsKKworCXZtX2Rldi0+ dmRldi5kZXYucGFyZW50ID0gZGV2OworCXZtX2Rldi0+dmRldi5kZXYucmVsZWFzZSA9IHZpcnRp b19tZGV2X3JlbGVhc2VfZGV2OworCXZtX2Rldi0+dmRldi5jb25maWcgPSAmdmlydGlvX21kZXZf Y29uZmlnX29wczsKKwl2bV9kZXYtPm1kZXYgPSBtZGV2OworCUlOSVRfTElTVF9IRUFEKCZ2bV9k ZXYtPnZpcnRxdWV1ZXMpOworCXNwaW5fbG9ja19pbml0KCZ2bV9kZXYtPmxvY2spOworCisJdm1f ZGV2LT5mZWF0dXJlcyA9IG9wcy0+Z2V0X21kZXZfZmVhdHVyZXMobWRldik7CisJaWYgKHZtX2Rl di0+ZmVhdHVyZXMgIT0gVklSVElPX01ERVZfRl9WRVJTSU9OXzEpIHsKKwkJZGV2X2VycihkZXYs ICJWSVJUSU9fTURFVl9GX1ZFUlNJT05fMSBpcyBtYW5kYXRvcnlcbiIpOworCQlyZXR1cm4gLUVO WElPOworCX0KKworCXZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPSBvcHMtPmdldF9kZXZpY2VfaWQo bWRldik7CisJaWYgKHZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPT0gMCkKKwkJcmV0dXJuIC1FTk9E RVY7CisKKwl2bV9kZXYtPnZkZXYuaWQudmVuZG9yID0gb3BzLT5nZXRfdmVuZG9yX2lkKG1kZXYp OworCXJjID0gcmVnaXN0ZXJfdmlydGlvX2RldmljZSgmdm1fZGV2LT52ZGV2KTsKKwlpZiAocmMp CisJCXB1dF9kZXZpY2UoZGV2KTsKKwllbHNlCisJCWRldl9zZXRfZHJ2ZGF0YShkZXYsIHZtX2Rl dik7CisKKwlyZXR1cm4gcmM7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3JlbW92ZShz dHJ1Y3QgZGV2aWNlICpkZXYpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2 ID0gZGV2X2dldF9kcnZkYXRhKGRldik7CisKKwl1bnJlZ2lzdGVyX3ZpcnRpb19kZXZpY2UoJnZt X2Rldi0+dmRldik7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3QgbWRldl9jbGFzc19pZCBpZF90 YWJsZVtdID0geworCXsgTURFVl9DTEFTU19JRF9WSVJUSU8gfSwKKwl7IDAgfSwKK307CisKK01P RFVMRV9ERVZJQ0VfVEFCTEUobWRldiwgaWRfdGFibGUpOworCitzdGF0aWMgc3RydWN0IG1kZXZf ZHJpdmVyIHZpcnRpb19tZGV2X2RyaXZlciA9IHsKKwkubmFtZQk9ICJ2aXJ0aW9fbWRldiIsCisJ LnByb2JlCT0gdmlydGlvX21kZXZfcHJvYmUsCisJLnJlbW92ZSA9IHZpcnRpb19tZGV2X3JlbW92 ZSwKKwkuaWRfdGFibGUgPSBpZF90YWJsZSwKK307CisKK3N0YXRpYyBpbnQgX19pbml0IHZpcnRp b19tZGV2X2luaXQodm9pZCkKK3sKKwlyZXR1cm4gbWRldl9yZWdpc3Rlcl9kcml2ZXIoJnZpcnRp b19tZGV2X2RyaXZlciwgVEhJU19NT0RVTEUpOworfQorCitzdGF0aWMgdm9pZCBfX2V4aXQgdmly dGlvX21kZXZfZXhpdCh2b2lkKQoreworCW1kZXZfdW5yZWdpc3Rlcl9kcml2ZXIoJnZpcnRpb19t ZGV2X2RyaXZlcik7Cit9CisKK21vZHVsZV9pbml0KHZpcnRpb19tZGV2X2luaXQpCittb2R1bGVf ZXhpdCh2aXJ0aW9fbWRldl9leGl0KQorCitNT0RVTEVfVkVSU0lPTihEUklWRVJfVkVSU0lPTik7 CitNT0RVTEVfTElDRU5TRSgiR1BMIHYyIik7CitNT0RVTEVfQVVUSE9SKERSSVZFUl9BVVRIT1Ip OworTU9EVUxFX0RFU0NSSVBUSU9OKERSSVZFUl9ERVNDKTsKLS0gCjIuMTkuMQoKX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KSW50ZWwtZ2Z4IG1haWxpbmcg bGlzdApJbnRlbC1nZnhAbGlzdHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBzOi8vbGlzdHMuZnJlZWRl c2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vaW50ZWwtZ2Z4