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=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 561A1C432C0 for ; Mon, 18 Nov 2019 11:02:48 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 1ADF32073A for ; Mon, 18 Nov 2019 11:02:48 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="Yfvv8J9s" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726596AbfKRLCr (ORCPT ); Mon, 18 Nov 2019 06:02:47 -0500 Received: from us-smtp-2.mimecast.com ([205.139.110.61]:54828 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726951AbfKRLCq (ORCPT ); Mon, 18 Nov 2019 06:02:46 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1574074963; 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=O9mTZX0fRz4Az5tS6O2SMzhtrRGL3+OTtnNT3CjGECg=; b=Yfvv8J9sYEvNxPsuLYdULsfc6W/DiK/IfIMQxGq3uTlxT9Ec0IWo/vRGXVck/Agq0XQtP7 yqVENB/C6vJtNamDXAqkUuL1NZ+edPfqR95PDFifIHgiKtC6gI3WnPoBxPkoJvRV/0idw7 5/C6vlVKUxfu0Fe3wqFvn0KIHiQBEKo= 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-160-wt8gg8UfPaqA9ucurp0gbw-1; Mon, 18 Nov 2019 06:02:41 -0500 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 1600A85EE6A; Mon, 18 Nov 2019 11:02:37 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-65.pek2.redhat.com [10.72.12.65]) by smtp.corp.redhat.com (Postfix) with ESMTP id 7652060BE1; Mon, 18 Nov 2019 11:02:08 +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, gregkh@linuxfoundation.org, jgg@mellanox.com Cc: 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, eperezma@redhat.com, lulu@redhat.com, parav@mellanox.com, christophe.de.dinechin@gmail.com, kevin.tian@intel.com, stefanha@redhat.com, rdunlap@infradead.org, hch@infradead.org, aadam@redhat.com, jakub.kicinski@netronome.com, jiri@mellanox.com, jeffrey.t.kirsher@intel.com, Jason Wang Subject: [PATCH V13 5/6] virtio: introduce a mdev based transport Date: Mon, 18 Nov 2019 18:59:22 +0800 Message-Id: <20191118105923.7991-6-jasowang@redhat.com> In-Reply-To: <20191118105923.7991-1-jasowang@redhat.com> References: <20191118105923.7991-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-MC-Unique: wt8gg8UfPaqA9ucurp0gbw-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 bus_ops of mdev parent. Signed-off-by: Jason Wang --- drivers/virtio/Kconfig | 13 ++ drivers/virtio/Makefile | 1 + drivers/virtio/virtio_mdev.c | 409 +++++++++++++++++++++++++++++++++++ include/linux/mdev_virtio.h | 5 + 4 files changed, 428 insertions(+) create mode 100644 drivers/virtio/virtio_mdev.c diff --git a/drivers/virtio/Kconfig b/drivers/virtio/Kconfig index 078615cf2afc..6a89b3de97d3 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 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..7fdb42f055df --- /dev/null +++ b/drivers/virtio/virtio_mdev.c @@ -0,0 +1,409 @@ +// 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 + +#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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_virtio_from_dev(dev); +=09const struct mdev_virtio_ops *ops =3D mdev_virtio_get_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_virtio_class_id virtio_id_table[] =3D { +=09{ MDEV_VIRTIO_CLASS_ID_VIRTIO }, +=09{ 0 }, +}; + +MODULE_DEVICE_TABLE(mdev_virtio, virtio_id_table); + +static struct mdev_virtio_driver virtio_mdev_driver =3D { +=09.drv =3D { +=09=09.name=09=3D "virtio_mdev", +=09=09.probe=09=3D virtio_mdev_probe, +=09=09.remove =3D virtio_mdev_remove, +=09}, +=09.id_table =3D virtio_id_table, +}; + +static int __init virtio_mdev_init(void) +{ +=09return mdev_register_driver(&virtio_mdev_driver.drv, THIS_MODULE, +=09=09=09=09 &mdev_virtio_bus_type); +} + +static void __exit virtio_mdev_exit(void) +{ +=09mdev_unregister_driver(&virtio_mdev_driver.drv); +} + +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); diff --git a/include/linux/mdev_virtio.h b/include/linux/mdev_virtio.h index ef2dbb6c383a..5f75f3cf59e1 100644 --- a/include/linux/mdev_virtio.h +++ b/include/linux/mdev_virtio.h @@ -25,6 +25,11 @@ struct virtio_mdev_callback { =09void *private; }; =20 +enum { +=09MDEV_VIRTIO_CLASS_ID_VIRTIO =3D 1, +=09/* New entries must be added here */ +}; + /** * struct mdev_virtio_device_ops - Structure to be registered for each * mdev device to register the device for virtio/vhost drivers. --=20 2.19.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jason Wang Subject: [PATCH V13 5/6] virtio: introduce a mdev based transport Date: Mon, 18 Nov 2019 18:59:22 +0800 Message-ID: <20191118105923.7991-6-jasowang@redhat.com> References: <20191118105923.7991-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: <20191118105923.7991-1-jasowang@redhat.com> Sender: linux-kernel-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, gregkh@linuxfoundation.org, jgg@mellanox.com Cc: 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, eperezma@redhat.com, lulu@redhat.com, parav@mellanox.com, christophe.de.dinechin@gmail.com, kevin.tian@intel.com, stefanha@redhat.com, rdunlap@infradead.org, hch@infradead.org, aadam@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 bus_ops of mdev parent. Signed-off-by: Jason Wang --- drivers/virtio/Kconfig | 13 ++ drivers/virtio/Makefile | 1 + drivers/virtio/virtio_mdev.c | 409 +++++++++++++++++++++++++++++++++++ include/linux/mdev_virtio.h | 5 + 4 files changed, 428 insertions(+) create mode 100644 drivers/virtio/virtio_mdev.c diff --git a/drivers/virtio/Kconfig b/drivers/virtio/Kconfig index 078615cf2afc..6a89b3de97d3 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 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..7fdb42f055df --- /dev/null +++ b/drivers/virtio/virtio_mdev.c @@ -0,0 +1,409 @@ +// 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 + +#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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_ops *ops =3D mdev_virtio_get_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_virtio_from_dev(dev); +=09const struct mdev_virtio_ops *ops =3D mdev_virtio_get_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_virtio_class_id virtio_id_table[] =3D { +=09{ MDEV_VIRTIO_CLASS_ID_VIRTIO }, +=09{ 0 }, +}; + +MODULE_DEVICE_TABLE(mdev_virtio, virtio_id_table); + +static struct mdev_virtio_driver virtio_mdev_driver =3D { +=09.drv =3D { +=09=09.name=09=3D "virtio_mdev", +=09=09.probe=09=3D virtio_mdev_probe, +=09=09.remove =3D virtio_mdev_remove, +=09}, +=09.id_table =3D virtio_id_table, +}; + +static int __init virtio_mdev_init(void) +{ +=09return mdev_register_driver(&virtio_mdev_driver.drv, THIS_MODULE, +=09=09=09=09 &mdev_virtio_bus_type); +} + +static void __exit virtio_mdev_exit(void) +{ +=09mdev_unregister_driver(&virtio_mdev_driver.drv); +} + +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); diff --git a/include/linux/mdev_virtio.h b/include/linux/mdev_virtio.h index ef2dbb6c383a..5f75f3cf59e1 100644 --- a/include/linux/mdev_virtio.h +++ b/include/linux/mdev_virtio.h @@ -25,6 +25,11 @@ struct virtio_mdev_callback { =09void *private; }; =20 +enum { +=09MDEV_VIRTIO_CLASS_ID_VIRTIO =3D 1, +=09/* New entries must be added here */ +}; + /** * struct mdev_virtio_device_ops - Structure to be registered for each * mdev device to register the device for virtio/vhost drivers. --=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 5B7F3C43215 for ; Mon, 18 Nov 2019 11:02:50 +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 3C04E2073A for ; Mon, 18 Nov 2019 11:02:50 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 3C04E2073A 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 14FF38979D; Mon, 18 Nov 2019 11:02:49 +0000 (UTC) Received: from us-smtp-delivery-1.mimecast.com (us-smtp-2.mimecast.com [205.139.110.61]) by gabe.freedesktop.org (Postfix) with ESMTPS id 303F68970B for ; Mon, 18 Nov 2019 11:02:46 +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-160-wt8gg8UfPaqA9ucurp0gbw-1; Mon, 18 Nov 2019 06:02:41 -0500 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 1600A85EE6A; Mon, 18 Nov 2019 11:02:37 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-65.pek2.redhat.com [10.72.12.65]) by smtp.corp.redhat.com (Postfix) with ESMTP id 7652060BE1; Mon, 18 Nov 2019 11:02:08 +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, gregkh@linuxfoundation.org, jgg@mellanox.com Subject: [PATCH V13 5/6] virtio: introduce a mdev based transport Date: Mon, 18 Nov 2019 18:59:22 +0800 Message-Id: <20191118105923.7991-6-jasowang@redhat.com> In-Reply-To: <20191118105923.7991-1-jasowang@redhat.com> References: <20191118105923.7991-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-MC-Unique: wt8gg8UfPaqA9ucurp0gbw-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=1574074965; 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=O9mTZX0fRz4Az5tS6O2SMzhtrRGL3+OTtnNT3CjGECg=; b=by/KluGpAAucQm3Jui4LvB/Z8tNA0s/HdMH64oXPa9/++N5vRZkoccNi4R2sb55tXYHSDt gQzdXrjg8TZr10xbiJAPxkmbZsTf0tjQJoyAdqAtN5nVd7VZO0uViS3PNyN9OYvLBXR5+p Izls1807EW+yrvyaOY0TPTYybHChOwE= 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: rdunlap@infradead.org, jakub.kicinski@netronome.com, christophe.de.dinechin@gmail.com, sebott@linux.ibm.com, airlied@linux.ie, Jason Wang , heiko.carstens@de.ibm.com, kevin.tian@intel.com, rob.miller@broadcom.com, hch@infradead.org, lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com, borntraeger@de.ibm.com, haotian.wang@sifive.com, jeffrey.t.kirsher@intel.com, zhi.a.wang@intel.com, farman@linux.ibm.com, parav@mellanox.com, gor@linux.ibm.com, cunming.liang@intel.com, rodrigo.vivi@intel.com, xiao.w.wang@intel.com, freude@linux.ibm.com, stefanha@redhat.com, zhihong.wang@intel.com, akrowiak@linux.ibm.com, jiri@mellanox.com, netdev@vger.kernel.org, cohuck@redhat.com, oberpar@linux.ibm.com, maxime.coquelin@redhat.com, aadam@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: <20191118105922.JlC2PFZ2fovEy7R5KrEdJHLkJEzBeyJEHC3i12owJ64@z> VGhpcyBwYXRjaCBpbnRyb2R1Y2VzIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZvciB2aXJ0aW8uIFRo aXMgaXMgdXNlZCB0bwp1c2Uga2VybmVsIHZpcnRpbyBkcml2ZXIgdG8gZHJpdmUgdGhlIG1lZGlh dGVkIGRldmljZSB0aGF0IGlzIGNhcGFibGUKb2YgcG9wdWxhdGluZyB2aXJ0cXVldWUgZGlyZWN0 bHkuCgpBIG5ldyB2aXJ0aW8tbWRldiBkcml2ZXIgd2lsbCBiZSByZWdpc3RlcmVkIHRvIHRoZSBt ZGV2IGJ1cywgd2hlbiBhCm5ldyB2aXJ0aW8tbWRldiBkZXZpY2UgaXMgcHJvYmVkLCBpdCB3aWxs IHJlZ2lzdGVyIHRoZSBkZXZpY2Ugd2l0aAptZGV2IGJhc2VkIGNvbmZpZyBvcHMuIFRoaXMgbWVh bnMgaXQgaXMgYSBzb2Z0d2FyZSB0cmFuc3BvcnQgYmV0d2VlbgptZGV2IGRyaXZlciBhbmQgbWRl diBkZXZpY2UuIFRoZSB0cmFuc3BvcnQgd2FzIGltcGxlbWVudGVkIHRocm91Z2gKYnVzX29wcyBv ZiBtZGV2IHBhcmVudC4KClNpZ25lZC1vZmYtYnk6IEphc29uIFdhbmcgPGphc293YW5nQHJlZGhh dC5jb20+Ci0tLQogZHJpdmVycy92aXJ0aW8vS2NvbmZpZyAgICAgICB8ICAxMyArKwogZHJpdmVy cy92aXJ0aW8vTWFrZWZpbGUgICAgICB8ICAgMSArCiBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRl di5jIHwgNDA5ICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrCiBpbmNsdWRlL2xp bnV4L21kZXZfdmlydGlvLmggIHwgICA1ICsKIDQgZmlsZXMgY2hhbmdlZCwgNDI4IGluc2VydGlv bnMoKykKIGNyZWF0ZSBtb2RlIDEwMDY0NCBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jCgpk aWZmIC0tZ2l0IGEvZHJpdmVycy92aXJ0aW8vS2NvbmZpZyBiL2RyaXZlcnMvdmlydGlvL0tjb25m aWcKaW5kZXggMDc4NjE1Y2YyYWZjLi42YTg5YjNkZTk3ZDMgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMv dmlydGlvL0tjb25maWcKKysrIGIvZHJpdmVycy92aXJ0aW8vS2NvbmZpZwpAQCAtNDMsNiArNDMs MTkgQEAgY29uZmlnIFZJUlRJT19QQ0lfTEVHQUNZCiAKIAkgIElmIHVuc3VyZSwgc2F5IFkuCiAK K2NvbmZpZyBWSVJUSU9fTURFVgorCXRyaXN0YXRlICJNREVWIGRyaXZlciBmb3IgdmlydGlvIGRl dmljZXMiCisJZGVwZW5kcyBvbiBNREVWX1ZJUlRJTworCWRlZmF1bHQgbgorCWhlbHAKKwkgIFRo aXMgZHJpdmVyIHByb3ZpZGVzIHN1cHBvcnQgZm9yIHZpcnRpbyBiYXNlZCBwYXJhdmlydHVhbAor CSAgZGV2aWNlIGRyaXZlciBvdmVyIE1ERVYgYnVzLiBGb3IgdGhpcyB0byBiZSB1c2VmdWwsIHlv dSBuZWVkCisJICBhbiBhcHByb3ByaWF0ZSB2aXJ0aW8gbWRldiBkZXZpY2UgaW1wbGVtZW50YXRp b24gdGhhdAorCSAgb3BlcmF0ZXMgb24gYSBwaHlzaWNhbCBkZXZpY2UgdG8gYWxsb3cgdGhlIGRh dGFwYXRoIG9mIHZpcnRpbworCSAgdG8gYmUgb2ZmbG9hZGVkIHRvIGhhcmR3YXJlLgorCisJICBJ ZiB1bnN1cmUsIHNheSBNLgorCiBjb25maWcgVklSVElPX1BNRU0KIAl0cmlzdGF0ZSAiU3VwcG9y dCBmb3IgdmlydGlvIHBtZW0gZHJpdmVyIgogCWRlcGVuZHMgb24gVklSVElPCmRpZmYgLS1naXQg YS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZSBiL2RyaXZlcnMvdmlydGlvL01ha2VmaWxlCmluZGV4 IDNhMmI1YzVkY2Y0Ni4uZjI5OTdiNmM4MTJmIDEwMDY0NAotLS0gYS9kcml2ZXJzL3ZpcnRpby9N YWtlZmlsZQorKysgYi9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZQpAQCAtNiwzICs2LDQgQEAgdmly dGlvX3BjaS15IDo9IHZpcnRpb19wY2lfbW9kZXJuLm8gdmlydGlvX3BjaV9jb21tb24ubwogdmly dGlvX3BjaS0kKENPTkZJR19WSVJUSU9fUENJX0xFR0FDWSkgKz0gdmlydGlvX3BjaV9sZWdhY3ku bwogb2JqLSQoQ09ORklHX1ZJUlRJT19CQUxMT09OKSArPSB2aXJ0aW9fYmFsbG9vbi5vCiBvYmot JChDT05GSUdfVklSVElPX0lOUFVUKSArPSB2aXJ0aW9faW5wdXQubworb2JqLSQoQ09ORklHX1ZJ UlRJT19NREVWKSArPSB2aXJ0aW9fbWRldi5vCmRpZmYgLS1naXQgYS9kcml2ZXJzL3ZpcnRpby92 aXJ0aW9fbWRldi5jIGIvZHJpdmVycy92aXJ0aW8vdmlydGlvX21kZXYuYwpuZXcgZmlsZSBtb2Rl IDEwMDY0NAppbmRleCAwMDAwMDAwMDAwMDAuLjdmZGI0MmYwNTVkZgotLS0gL2Rldi9udWxsCisr KyBiL2RyaXZlcnMvdmlydGlvL3ZpcnRpb19tZGV2LmMKQEAgLTAsMCArMSw0MDkgQEAKKy8vIFNQ RFgtTGljZW5zZS1JZGVudGlmaWVyOiBHUEwtMi4wLW9ubHkKKy8qCisgKiBWSVJUSU8gYmFzZWQg ZHJpdmVyIGZvciBNZWRpYXRlZCBkZXZpY2UKKyAqCisgKiBDb3B5cmlnaHQgKGMpIDIwMTksIFJl ZCBIYXQuIEFsbCByaWdodHMgcmVzZXJ2ZWQuCisgKiAgICAgQXV0aG9yOiBKYXNvbiBXYW5nIDxq YXNvd2FuZ0ByZWRoYXQuY29tPgorICoKKyAqLworCisjaW5jbHVkZSA8bGludXgvaW5pdC5oPgor I2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgorI2luY2x1ZGUgPGxpbnV4L2RldmljZS5oPgorI2lu Y2x1ZGUgPGxpbnV4L2tlcm5lbC5oPgorI2luY2x1ZGUgPGxpbnV4L3NsYWIuaD4KKyNpbmNsdWRl IDxsaW51eC91dWlkLmg+CisjaW5jbHVkZSA8bGludXgvdmlydGlvLmg+CisjaW5jbHVkZSA8bGlu dXgvbWRldl92aXJ0aW8uaD4KKyNpbmNsdWRlIDxsaW51eC92aXJ0aW9fY29uZmlnLmg+CisjaW5j bHVkZSA8bGludXgvdmlydGlvX3JpbmcuaD4KKworI2RlZmluZSBEUklWRVJfVkVSU0lPTiAgIjAu MSIKKyNkZWZpbmUgRFJJVkVSX0FVVEhPUiAgICJSZWQgSGF0IENvcnBvcmF0aW9uIgorI2RlZmlu ZSBEUklWRVJfREVTQyAgICAgIlZJUlRJTyBiYXNlZCBkcml2ZXIgZm9yIE1lZGlhdGVkIGRldmlj ZSIKKworI2RlZmluZSB0b192aXJ0aW9fbWRldl9kZXZpY2UoZGV2KSBcCisJY29udGFpbmVyX29m KGRldiwgc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSwgdmRldikKKworc3RydWN0IHZpcnRpb19t ZGV2X2RldmljZSB7CisJc3RydWN0IHZpcnRpb19kZXZpY2UgdmRldjsKKwlzdHJ1Y3QgbWRldl9k ZXZpY2UgKm1kZXY7CisJdTY0IGZlYXR1cmVzOworCisJLyogVGhlIGxvY2sgdG8gcHJvdGVjdCB2 aXJ0cXVldWUgbGlzdCAqLworCXNwaW5sb2NrX3QgbG9jazsKKwkvKiBMaXN0IG9mIHZpcnRpb19t ZGV2X3ZxX2luZm8gKi8KKwlzdHJ1Y3QgbGlzdF9oZWFkIHZpcnRxdWV1ZXM7Cit9OworCitzdHJ1 Y3QgdmlydGlvX21kZXZfdnFfaW5mbyB7CisJLyogdGhlIGFjdHVhbCB2aXJ0cXVldWUgKi8KKwlz dHJ1Y3QgdmlydHF1ZXVlICp2cTsKKworCS8qIHRoZSBsaXN0IG5vZGUgZm9yIHRoZSB2aXJ0cXVl dWVzIGxpc3QgKi8KKwlzdHJ1Y3QgbGlzdF9oZWFkIG5vZGU7Cit9OworCitzdGF0aWMgc3RydWN0 IG1kZXZfZGV2aWNlICp2bV9nZXRfbWRldihzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sK KwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSB0b192aXJ0aW9fbWRldl9kZXZp Y2UodmRldik7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZGV2LT5tZGV2OworCisJ cmV0dXJuIG1kZXY7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X2dldChzdHJ1Y3Qgdmly dGlvX2RldmljZSAqdmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJICAgIHZvaWQgKmJ1ZiwgdW5z aWduZWQgbGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZk ZXYpOworCWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dl dF9vcHMobWRldik7CisKKwlvcHMtPmdldF9jb25maWcobWRldiwgb2Zmc2V0LCBidWYsIGxlbik7 Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3NldChzdHJ1Y3QgdmlydGlvX2RldmljZSAq dmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJICAgIGNvbnN0IHZvaWQgKmJ1ZiwgdW5zaWduZWQg bGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOwor CWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dldF9vcHMo bWRldik7CisKKwlvcHMtPnNldF9jb25maWcobWRldiwgb2Zmc2V0LCBidWYsIGxlbik7Cit9CisK K3N0YXRpYyB1MzIgdmlydGlvX21kZXZfZ2VuZXJhdGlvbihzdHJ1Y3QgdmlydGlvX2RldmljZSAq dmRldikKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsK Kwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3Bz KG1kZXYpOworCisKKwlpZiAob3BzLT5nZXRfZ2VuZXJhdGlvbikKKwkJcmV0dXJuIG9wcy0+Z2V0 X2dlbmVyYXRpb24obWRldik7CisKKwlyZXR1cm4gMDsKK30KKworc3RhdGljIHU4IHZpcnRpb19t ZGV2X2dldF9zdGF0dXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3RydWN0IG1k ZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3RydWN0IG1kZXZf dmlydGlvX29wcyAqb3BzID0gbWRldl92aXJ0aW9fZ2V0X29wcyhtZGV2KTsKKworCXJldHVybiBv cHMtPmdldF9zdGF0dXMobWRldik7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3NldF9z dGF0dXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYsIHU4IHN0YXR1cykKK3sKKwlzdHJ1Y3Qg bWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRl dl92aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJcmV0dXJu IG9wcy0+c2V0X3N0YXR1cyhtZGV2LCBzdGF0dXMpOworfQorCitzdGF0aWMgdm9pZCB2aXJ0aW9f bWRldl9yZXNldChzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRldl9k ZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0 aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJcmV0dXJuIG9wcy0+ c2V0X3N0YXR1cyhtZGV2LCAwKTsKK30KKworc3RhdGljIGJvb2wgdmlydGlvX21kZXZfbm90aWZ5 KHN0cnVjdCB2aXJ0cXVldWUgKnZxKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZt X2dldF9tZGV2KHZxLT52ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fb3BzICpvcHMg PSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJb3BzLT5raWNrX3ZxKG1kZXYsIHZxLT5p bmRleCk7CisKKwlyZXR1cm4gdHJ1ZTsKK30KKworc3RhdGljIGlycXJldHVybl90IHZpcnRpb19t ZGV2X2NvbmZpZ19jYih2b2lkICpwcml2YXRlKQoreworCXN0cnVjdCB2aXJ0aW9fbWRldl9kZXZp Y2UgKnZtX2RldiA9IHByaXZhdGU7CisKKwl2aXJ0aW9fY29uZmlnX2NoYW5nZWQoJnZtX2Rldi0+ dmRldik7CisKKwlyZXR1cm4gSVJRX0hBTkRMRUQ7Cit9CisKK3N0YXRpYyBpcnFyZXR1cm5fdCB2 aXJ0aW9fbWRldl92aXJ0cXVldWVfY2Iodm9pZCAqcHJpdmF0ZSkKK3sKKwlzdHJ1Y3QgdmlydGlv X21kZXZfdnFfaW5mbyAqaW5mbyA9IHByaXZhdGU7CisKKwlyZXR1cm4gdnJpbmdfaW50ZXJydXB0 KDAsIGluZm8tPnZxKTsKK30KKworc3RhdGljIHN0cnVjdCB2aXJ0cXVldWUgKgordmlydGlvX21k ZXZfc2V0dXBfdnEoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYsIHVuc2lnbmVkIGludCBpbmRl eCwKKwkJICAgICB2b2lkICgqY2FsbGJhY2spKHN0cnVjdCB2aXJ0cXVldWUgKnZxKSwKKwkJICAg ICBjb25zdCBjaGFyICpuYW1lLCBib29sIGN0eCkKK3sKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlICp2bV9kZXYgPSB0b192aXJ0aW9fbWRldl9kZXZpY2UodmRldik7CisJc3RydWN0IG1kZXZf ZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3RydWN0IG1kZXZfdmly dGlvX29wcyAqb3BzID0gbWRldl92aXJ0aW9fZ2V0X29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlv X21kZXZfdnFfaW5mbyAqaW5mbzsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfY2FsbGJhY2sgY2I7CisJ c3RydWN0IHZpcnRxdWV1ZSAqdnE7CisJdTY0IGRlc2NfYWRkciwgZHJpdmVyX2FkZHIsIGRldmlj ZV9hZGRyOworCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CisJdTMyIGFsaWduLCBudW07CisJaW50IGVy cjsKKworCWlmICghbmFtZSkKKwkJcmV0dXJuIE5VTEw7CisKKwkvKiBRdWV1ZSBzaG91bGRuJ3Qg YWxyZWFkeSBiZSBzZXQgdXAuICovCisJaWYgKG9wcy0+Z2V0X3ZxX3JlYWR5KG1kZXYsIGluZGV4 KSkKKwkJcmV0dXJuIEVSUl9QVFIoLUVOT0VOVCk7CisKKwkvKiBBbGxvY2F0ZSBhbmQgZmlsbCBv dXQgb3VyIGFjdGl2ZSBxdWV1ZSBkZXNjcmlwdGlvbiAqLworCWluZm8gPSBrbWFsbG9jKHNpemVv ZigqaW5mbyksIEdGUF9LRVJORUwpOworCWlmICghaW5mbykKKwkJcmV0dXJuIEVSUl9QVFIoLUVO T01FTSk7CisKKwludW0gPSBvcHMtPmdldF92cV9udW1fbWF4KG1kZXYpOworCWlmIChudW0gPT0g MCkgeworCQllcnIgPSAtRU5PRU5UOworCQlnb3RvIGVycm9yX25ld192aXJ0cXVldWU7CisJfQor CisJLyogQ3JlYXRlIHRoZSB2cmluZyAqLworCWFsaWduID0gb3BzLT5nZXRfdnFfYWxpZ24obWRl dik7CisJdnEgPSB2cmluZ19jcmVhdGVfdmlydHF1ZXVlKGluZGV4LCBudW0sIGFsaWduLCB2ZGV2 LAorCQkJCSAgICB0cnVlLCB0cnVlLCBjdHgsCisJCQkJICAgIHZpcnRpb19tZGV2X25vdGlmeSwg Y2FsbGJhY2ssIG5hbWUpOworCWlmICghdnEpIHsKKwkJZXJyID0gLUVOT01FTTsKKwkJZ290byBl cnJvcl9uZXdfdmlydHF1ZXVlOworCX0KKworCS8qIFNldHVwIHZpcnRxdWV1ZSBjYWxsYmFjayAq LworCWNiLmNhbGxiYWNrID0gdmlydGlvX21kZXZfdmlydHF1ZXVlX2NiOworCWNiLnByaXZhdGUg PSBpbmZvOworCW9wcy0+c2V0X3ZxX2NiKG1kZXYsIGluZGV4LCAmY2IpOworCW9wcy0+c2V0X3Zx X251bShtZGV2LCBpbmRleCwgdmlydHF1ZXVlX2dldF92cmluZ19zaXplKHZxKSk7CisKKwlkZXNj X2FkZHIgPSB2aXJ0cXVldWVfZ2V0X2Rlc2NfYWRkcih2cSk7CisJZHJpdmVyX2FkZHIgPSB2aXJ0 cXVldWVfZ2V0X2F2YWlsX2FkZHIodnEpOworCWRldmljZV9hZGRyID0gdmlydHF1ZXVlX2dldF91 c2VkX2FkZHIodnEpOworCisJaWYgKG9wcy0+c2V0X3ZxX2FkZHJlc3MobWRldiwgaW5kZXgsCisJ CQkJZGVzY19hZGRyLCBkcml2ZXJfYWRkciwKKwkJCQlkZXZpY2VfYWRkcikpIHsKKwkJZXJyID0g LUVJTlZBTDsKKwkJZ290byBlcnJfdnE7CisJfQorCisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwg aW5kZXgsIDEpOworCisJdnEtPnByaXYgPSBpbmZvOworCWluZm8tPnZxID0gdnE7CisKKwlzcGlu X2xvY2tfaXJxc2F2ZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisJbGlzdF9hZGQoJmluZm8tPm5v ZGUsICZ2bV9kZXYtPnZpcnRxdWV1ZXMpOworCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJnZtX2Rl di0+bG9jaywgZmxhZ3MpOworCisJcmV0dXJuIHZxOworCitlcnJfdnE6CisJdnJpbmdfZGVsX3Zp cnRxdWV1ZSh2cSk7CitlcnJvcl9uZXdfdmlydHF1ZXVlOgorCW9wcy0+c2V0X3ZxX3JlYWR5KG1k ZXYsIGluZGV4LCAwKTsKKwlXQVJOX09OKG9wcy0+Z2V0X3ZxX3JlYWR5KG1kZXYsIGluZGV4KSk7 CisJa2ZyZWUoaW5mbyk7CisJcmV0dXJuIEVSUl9QVFIoZXJyKTsKK30KKworc3RhdGljIHZvaWQg dmlydGlvX21kZXZfZGVsX3ZxKHN0cnVjdCB2aXJ0cXVldWUgKnZxKQoreworCXN0cnVjdCB2aXJ0 aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2RldmljZSh2cS0+dmRldik7 CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZGV2LT5tZGV2OworCWNvbnN0IHN0cnVj dCBtZGV2X3ZpcnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dldF9vcHMobWRldik7CisJc3Ry dWN0IHZpcnRpb19tZGV2X3ZxX2luZm8gKmluZm8gPSB2cS0+cHJpdjsKKwl1bnNpZ25lZCBpbnQg aW5kZXggPSB2cS0+aW5kZXg7CisJdW5zaWduZWQgbG9uZyBmbGFnczsKKworCXNwaW5fbG9ja19p cnFzYXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2RlbCgmaW5mby0+bm9kZSk7CisJ c3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisKKwkvKiBTZWxl Y3QgYW5kIGRlYWN0aXZhdGUgdGhlIHF1ZXVlICovCisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwg aW5kZXgsIDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKTsKKwor CXZyaW5nX2RlbF92aXJ0cXVldWUodnEpOworCisJa2ZyZWUoaW5mbyk7Cit9CisKK3N0YXRpYyB2 b2lkIHZpcnRpb19tZGV2X2RlbF92cXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJ c3RydWN0IHZpcnRxdWV1ZSAqdnEsICpuOworCisJbGlzdF9mb3JfZWFjaF9lbnRyeV9zYWZlKHZx LCBuLCAmdmRldi0+dnFzLCBsaXN0KQorCQl2aXJ0aW9fbWRldl9kZWxfdnEodnEpOworfQorCitz dGF0aWMgaW50IHZpcnRpb19tZGV2X2ZpbmRfdnFzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2 LCB1bnNpZ25lZCBudnFzLAorCQkJCXN0cnVjdCB2aXJ0cXVldWUgKnZxc1tdLAorCQkJCXZxX2Nh bGxiYWNrX3QgKmNhbGxiYWNrc1tdLAorCQkJCWNvbnN0IGNoYXIgKiBjb25zdCBuYW1lc1tdLAor CQkJCWNvbnN0IGJvb2wgKmN0eCwKKwkJCQlzdHJ1Y3QgaXJxX2FmZmluaXR5ICpkZXNjKQorewor CXN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2Rldmlj ZSh2ZGV2KTsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsK Kwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3Bz KG1kZXYpOworCXN0cnVjdCB2aXJ0aW9fbWRldl9jYWxsYmFjayBjYjsKKwlpbnQgaSwgZXJyLCBx dWV1ZV9pZHggPSAwOworCisJZm9yIChpID0gMDsgaSA8IG52cXM7ICsraSkgeworCQlpZiAoIW5h bWVzW2ldKSB7CisJCQl2cXNbaV0gPSBOVUxMOworCQkJY29udGludWU7CisJCX0KKworCQl2cXNb aV0gPSB2aXJ0aW9fbWRldl9zZXR1cF92cSh2ZGV2LCBxdWV1ZV9pZHgrKywKKwkJCQkJICAgICAg Y2FsbGJhY2tzW2ldLCBuYW1lc1tpXSwgY3R4ID8KKwkJCQkJICAgICAgY3R4W2ldIDogZmFsc2Up OworCQlpZiAoSVNfRVJSKHZxc1tpXSkpIHsKKwkJCWVyciA9IFBUUl9FUlIodnFzW2ldKTsKKwkJ CWdvdG8gZXJyX3NldHVwX3ZxOworCQl9CisJfQorCisJY2IuY2FsbGJhY2sgPSB2aXJ0aW9fbWRl dl9jb25maWdfY2I7CisJY2IucHJpdmF0ZSA9IHZtX2RldjsKKwlvcHMtPnNldF9jb25maWdfY2Io bWRldiwgJmNiKTsKKworCXJldHVybiAwOworCitlcnJfc2V0dXBfdnE6CisJdmlydGlvX21kZXZf ZGVsX3Zxcyh2ZGV2KTsKKwlyZXR1cm4gZXJyOworfQorCitzdGF0aWMgdTY0IHZpcnRpb19tZGV2 X2dldF9mZWF0dXJlcyhzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRl dl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92 aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJcmV0dXJuIG9w cy0+Z2V0X2ZlYXR1cmVzKG1kZXYpOworfQorCitzdGF0aWMgaW50IHZpcnRpb19tZGV2X2ZpbmFs aXplX2ZlYXR1cmVzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2KQoreworCXN0cnVjdCBtZGV2 X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCBtZGV2X3Zp cnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dldF9vcHMobWRldik7CisKKwkvKiBHaXZlIHZp cnRpb19yaW5nIGEgY2hhbmNlIHRvIGFjY2VwdCBmZWF0dXJlcy4gKi8KKwl2cmluZ190cmFuc3Bv cnRfZmVhdHVyZXModmRldik7CisKKwlyZXR1cm4gb3BzLT5zZXRfZmVhdHVyZXMobWRldiwgdmRl di0+ZmVhdHVyZXMpOworfQorCitzdGF0aWMgY29uc3QgY2hhciAqdmlydGlvX21kZXZfYnVzX25h bWUoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2Rl dmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZkZXYpOworCXN0cnVjdCBtZGV2 X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsKKworCXJldHVybiBkZXZfbmFtZShtZGV2X2Rl dihtZGV2KSk7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3QgdmlydGlvX2NvbmZpZ19vcHMgdmly dGlvX21kZXZfY29uZmlnX29wcyA9IHsKKwkuZ2V0CQk9IHZpcnRpb19tZGV2X2dldCwKKwkuc2V0 CQk9IHZpcnRpb19tZGV2X3NldCwKKwkuZ2VuZXJhdGlvbgk9IHZpcnRpb19tZGV2X2dlbmVyYXRp b24sCisJLmdldF9zdGF0dXMJPSB2aXJ0aW9fbWRldl9nZXRfc3RhdHVzLAorCS5zZXRfc3RhdHVz CT0gdmlydGlvX21kZXZfc2V0X3N0YXR1cywKKwkucmVzZXQJCT0gdmlydGlvX21kZXZfcmVzZXQs CisJLmZpbmRfdnFzCT0gdmlydGlvX21kZXZfZmluZF92cXMsCisJLmRlbF92cXMJPSB2aXJ0aW9f bWRldl9kZWxfdnFzLAorCS5nZXRfZmVhdHVyZXMJPSB2aXJ0aW9fbWRldl9nZXRfZmVhdHVyZXMs CisJLmZpbmFsaXplX2ZlYXR1cmVzID0gdmlydGlvX21kZXZfZmluYWxpemVfZmVhdHVyZXMsCisJ LmJ1c19uYW1lCT0gdmlydGlvX21kZXZfYnVzX25hbWUsCit9OworCitzdGF0aWMgdm9pZCB2aXJ0 aW9fbWRldl9yZWxlYXNlX2RldihzdHJ1Y3QgZGV2aWNlICpfZCkKK3sKKwlzdHJ1Y3QgdmlydGlv X2RldmljZSAqdmRldiA9CisJICAgICAgIGNvbnRhaW5lcl9vZihfZCwgc3RydWN0IHZpcnRpb19k ZXZpY2UsIGRldik7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0KKwkgICAg ICAgY29udGFpbmVyX29mKHZkZXYsIHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UsIHZkZXYpOwor CXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsKKworCWRldm1fa2ZyZWUo bWRldl9kZXYobWRldiksIHZtX2Rldik7Cit9CisKK3N0YXRpYyBpbnQgdmlydGlvX21kZXZfcHJv YmUoc3RydWN0IGRldmljZSAqZGV2KQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IG1k ZXZfdmlydGlvX2Zyb21fZGV2KGRldik7CisJY29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX29wcyAq b3BzID0gbWRldl92aXJ0aW9fZ2V0X29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlICp2bV9kZXY7CisJaW50IHJjOworCisJdm1fZGV2ID0gZGV2bV9remFsbG9jKGRldiwgc2l6 ZW9mKCp2bV9kZXYpLCBHRlBfS0VSTkVMKTsKKwlpZiAoIXZtX2RldikKKwkJcmV0dXJuIC1FTk9N RU07CisKKwl2bV9kZXYtPnZkZXYuZGV2LnBhcmVudCA9IGRldjsKKwl2bV9kZXYtPnZkZXYuZGV2 LnJlbGVhc2UgPSB2aXJ0aW9fbWRldl9yZWxlYXNlX2RldjsKKwl2bV9kZXYtPnZkZXYuY29uZmln ID0gJnZpcnRpb19tZGV2X2NvbmZpZ19vcHM7CisJdm1fZGV2LT5tZGV2ID0gbWRldjsKKwlJTklU X0xJU1RfSEVBRCgmdm1fZGV2LT52aXJ0cXVldWVzKTsKKwlzcGluX2xvY2tfaW5pdCgmdm1fZGV2 LT5sb2NrKTsKKworCXZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPSBvcHMtPmdldF9kZXZpY2VfaWQo bWRldik7CisJaWYgKHZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPT0gMCkKKwkJcmV0dXJuIC1FTk9E RVY7CisKKwl2bV9kZXYtPnZkZXYuaWQudmVuZG9yID0gb3BzLT5nZXRfdmVuZG9yX2lkKG1kZXYp OworCXJjID0gcmVnaXN0ZXJfdmlydGlvX2RldmljZSgmdm1fZGV2LT52ZGV2KTsKKwlpZiAocmMp CisJCXB1dF9kZXZpY2UoZGV2KTsKKwllbHNlCisJCWRldl9zZXRfZHJ2ZGF0YShkZXYsIHZtX2Rl dik7CisKKwlyZXR1cm4gcmM7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3JlbW92ZShz dHJ1Y3QgZGV2aWNlICpkZXYpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2 ID0gZGV2X2dldF9kcnZkYXRhKGRldik7CisKKwl1bnJlZ2lzdGVyX3ZpcnRpb19kZXZpY2UoJnZt X2Rldi0+dmRldik7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fY2xhc3Nf aWQgdmlydGlvX2lkX3RhYmxlW10gPSB7CisJeyBNREVWX1ZJUlRJT19DTEFTU19JRF9WSVJUSU8g fSwKKwl7IDAgfSwKK307CisKK01PRFVMRV9ERVZJQ0VfVEFCTEUobWRldl92aXJ0aW8sIHZpcnRp b19pZF90YWJsZSk7CisKK3N0YXRpYyBzdHJ1Y3QgbWRldl92aXJ0aW9fZHJpdmVyIHZpcnRpb19t ZGV2X2RyaXZlciA9IHsKKwkuZHJ2ID0geworCQkubmFtZQk9ICJ2aXJ0aW9fbWRldiIsCisJCS5w cm9iZQk9IHZpcnRpb19tZGV2X3Byb2JlLAorCQkucmVtb3ZlID0gdmlydGlvX21kZXZfcmVtb3Zl LAorCX0sCisJLmlkX3RhYmxlID0gdmlydGlvX2lkX3RhYmxlLAorfTsKKworc3RhdGljIGludCBf X2luaXQgdmlydGlvX21kZXZfaW5pdCh2b2lkKQoreworCXJldHVybiBtZGV2X3JlZ2lzdGVyX2Ry aXZlcigmdmlydGlvX21kZXZfZHJpdmVyLmRydiwgVEhJU19NT0RVTEUsCisJCQkJICAgICZtZGV2 X3ZpcnRpb19idXNfdHlwZSk7Cit9CisKK3N0YXRpYyB2b2lkIF9fZXhpdCB2aXJ0aW9fbWRldl9l eGl0KHZvaWQpCit7CisJbWRldl91bnJlZ2lzdGVyX2RyaXZlcigmdmlydGlvX21kZXZfZHJpdmVy LmRydik7Cit9CisKK21vZHVsZV9pbml0KHZpcnRpb19tZGV2X2luaXQpCittb2R1bGVfZXhpdCh2 aXJ0aW9fbWRldl9leGl0KQorCitNT0RVTEVfVkVSU0lPTihEUklWRVJfVkVSU0lPTik7CitNT0RV TEVfTElDRU5TRSgiR1BMIHYyIik7CitNT0RVTEVfQVVUSE9SKERSSVZFUl9BVVRIT1IpOworTU9E VUxFX0RFU0NSSVBUSU9OKERSSVZFUl9ERVNDKTsKZGlmZiAtLWdpdCBhL2luY2x1ZGUvbGludXgv bWRldl92aXJ0aW8uaCBiL2luY2x1ZGUvbGludXgvbWRldl92aXJ0aW8uaAppbmRleCBlZjJkYmI2 YzM4M2EuLjVmNzVmM2NmNTllMSAxMDA2NDQKLS0tIGEvaW5jbHVkZS9saW51eC9tZGV2X3ZpcnRp by5oCisrKyBiL2luY2x1ZGUvbGludXgvbWRldl92aXJ0aW8uaApAQCAtMjUsNiArMjUsMTEgQEAg c3RydWN0IHZpcnRpb19tZGV2X2NhbGxiYWNrIHsKIAl2b2lkICpwcml2YXRlOwogfTsKIAorZW51 bSB7CisJTURFVl9WSVJUSU9fQ0xBU1NfSURfVklSVElPID0gMSwKKwkvKiBOZXcgZW50cmllcyBt dXN0IGJlIGFkZGVkIGhlcmUgKi8KK307CisKIC8qKgogICogc3RydWN0IG1kZXZfdmlydGlvX2Rl dmljZV9vcHMgLSBTdHJ1Y3R1cmUgdG8gYmUgcmVnaXN0ZXJlZCBmb3IgZWFjaAogICogbWRldiBk ZXZpY2UgdG8gcmVnaXN0ZXIgdGhlIGRldmljZSBmb3IgdmlydGlvL3Zob3N0IGRyaXZlcnMuCi0t IAoyLjE5LjEKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f CmRyaS1kZXZlbCBtYWlsaW5nIGxpc3QKZHJpLWRldmVsQGxpc3RzLmZyZWVkZXNrdG9wLm9yZwpo dHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2RyaS1kZXZlbA== 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 43FACC432C3 for ; Mon, 18 Nov 2019 11:02:49 +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 220922073A for ; Mon, 18 Nov 2019 11:02:49 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 220922073A 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 4695389722; Mon, 18 Nov 2019 11:02:48 +0000 (UTC) Received: from us-smtp-1.mimecast.com (us-smtp-delivery-1.mimecast.com [205.139.110.120]) by gabe.freedesktop.org (Postfix) with ESMTPS id 3ACAB89725 for ; Mon, 18 Nov 2019 11:02:46 +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-160-wt8gg8UfPaqA9ucurp0gbw-1; Mon, 18 Nov 2019 06:02:41 -0500 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 1600A85EE6A; Mon, 18 Nov 2019 11:02:37 +0000 (UTC) Received: from jason-ThinkPad-X1-Carbon-6th.redhat.com (ovpn-12-65.pek2.redhat.com [10.72.12.65]) by smtp.corp.redhat.com (Postfix) with ESMTP id 7652060BE1; Mon, 18 Nov 2019 11:02:08 +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, gregkh@linuxfoundation.org, jgg@mellanox.com Date: Mon, 18 Nov 2019 18:59:22 +0800 Message-Id: <20191118105923.7991-6-jasowang@redhat.com> In-Reply-To: <20191118105923.7991-1-jasowang@redhat.com> References: <20191118105923.7991-1-jasowang@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 X-MC-Unique: wt8gg8UfPaqA9ucurp0gbw-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=1574074965; 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=O9mTZX0fRz4Az5tS6O2SMzhtrRGL3+OTtnNT3CjGECg=; b=by/KluGpAAucQm3Jui4LvB/Z8tNA0s/HdMH64oXPa9/++N5vRZkoccNi4R2sb55tXYHSDt gQzdXrjg8TZr10xbiJAPxkmbZsTf0tjQJoyAdqAtN5nVd7VZO0uViS3PNyN9OYvLBXR5+p Izls1807EW+yrvyaOY0TPTYybHChOwE= Subject: [Intel-gfx] [PATCH V13 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: rdunlap@infradead.org, jakub.kicinski@netronome.com, christophe.de.dinechin@gmail.com, sebott@linux.ibm.com, airlied@linux.ie, Jason Wang , heiko.carstens@de.ibm.com, rob.miller@broadcom.com, hch@infradead.org, lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com, borntraeger@de.ibm.com, haotian.wang@sifive.com, jeffrey.t.kirsher@intel.com, farman@linux.ibm.com, parav@mellanox.com, gor@linux.ibm.com, cunming.liang@intel.com, xiao.w.wang@intel.com, freude@linux.ibm.com, stefanha@redhat.com, zhihong.wang@intel.com, akrowiak@linux.ibm.com, jiri@mellanox.com, netdev@vger.kernel.org, cohuck@redhat.com, oberpar@linux.ibm.com, maxime.coquelin@redhat.com, aadam@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: <20191118105922.d8diMnM-OeP4-7TSQGOu2HkjfkIsJ-o_fj_UaAq2EmQ@z> VGhpcyBwYXRjaCBpbnRyb2R1Y2VzIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZvciB2aXJ0aW8uIFRo aXMgaXMgdXNlZCB0bwp1c2Uga2VybmVsIHZpcnRpbyBkcml2ZXIgdG8gZHJpdmUgdGhlIG1lZGlh dGVkIGRldmljZSB0aGF0IGlzIGNhcGFibGUKb2YgcG9wdWxhdGluZyB2aXJ0cXVldWUgZGlyZWN0 bHkuCgpBIG5ldyB2aXJ0aW8tbWRldiBkcml2ZXIgd2lsbCBiZSByZWdpc3RlcmVkIHRvIHRoZSBt ZGV2IGJ1cywgd2hlbiBhCm5ldyB2aXJ0aW8tbWRldiBkZXZpY2UgaXMgcHJvYmVkLCBpdCB3aWxs IHJlZ2lzdGVyIHRoZSBkZXZpY2Ugd2l0aAptZGV2IGJhc2VkIGNvbmZpZyBvcHMuIFRoaXMgbWVh bnMgaXQgaXMgYSBzb2Z0d2FyZSB0cmFuc3BvcnQgYmV0d2VlbgptZGV2IGRyaXZlciBhbmQgbWRl diBkZXZpY2UuIFRoZSB0cmFuc3BvcnQgd2FzIGltcGxlbWVudGVkIHRocm91Z2gKYnVzX29wcyBv ZiBtZGV2IHBhcmVudC4KClNpZ25lZC1vZmYtYnk6IEphc29uIFdhbmcgPGphc293YW5nQHJlZGhh dC5jb20+Ci0tLQogZHJpdmVycy92aXJ0aW8vS2NvbmZpZyAgICAgICB8ICAxMyArKwogZHJpdmVy cy92aXJ0aW8vTWFrZWZpbGUgICAgICB8ICAgMSArCiBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRl di5jIHwgNDA5ICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrCiBpbmNsdWRlL2xp bnV4L21kZXZfdmlydGlvLmggIHwgICA1ICsKIDQgZmlsZXMgY2hhbmdlZCwgNDI4IGluc2VydGlv bnMoKykKIGNyZWF0ZSBtb2RlIDEwMDY0NCBkcml2ZXJzL3ZpcnRpby92aXJ0aW9fbWRldi5jCgpk aWZmIC0tZ2l0IGEvZHJpdmVycy92aXJ0aW8vS2NvbmZpZyBiL2RyaXZlcnMvdmlydGlvL0tjb25m aWcKaW5kZXggMDc4NjE1Y2YyYWZjLi42YTg5YjNkZTk3ZDMgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMv dmlydGlvL0tjb25maWcKKysrIGIvZHJpdmVycy92aXJ0aW8vS2NvbmZpZwpAQCAtNDMsNiArNDMs MTkgQEAgY29uZmlnIFZJUlRJT19QQ0lfTEVHQUNZCiAKIAkgIElmIHVuc3VyZSwgc2F5IFkuCiAK K2NvbmZpZyBWSVJUSU9fTURFVgorCXRyaXN0YXRlICJNREVWIGRyaXZlciBmb3IgdmlydGlvIGRl dmljZXMiCisJZGVwZW5kcyBvbiBNREVWX1ZJUlRJTworCWRlZmF1bHQgbgorCWhlbHAKKwkgIFRo aXMgZHJpdmVyIHByb3ZpZGVzIHN1cHBvcnQgZm9yIHZpcnRpbyBiYXNlZCBwYXJhdmlydHVhbAor CSAgZGV2aWNlIGRyaXZlciBvdmVyIE1ERVYgYnVzLiBGb3IgdGhpcyB0byBiZSB1c2VmdWwsIHlv dSBuZWVkCisJICBhbiBhcHByb3ByaWF0ZSB2aXJ0aW8gbWRldiBkZXZpY2UgaW1wbGVtZW50YXRp b24gdGhhdAorCSAgb3BlcmF0ZXMgb24gYSBwaHlzaWNhbCBkZXZpY2UgdG8gYWxsb3cgdGhlIGRh dGFwYXRoIG9mIHZpcnRpbworCSAgdG8gYmUgb2ZmbG9hZGVkIHRvIGhhcmR3YXJlLgorCisJICBJ ZiB1bnN1cmUsIHNheSBNLgorCiBjb25maWcgVklSVElPX1BNRU0KIAl0cmlzdGF0ZSAiU3VwcG9y dCBmb3IgdmlydGlvIHBtZW0gZHJpdmVyIgogCWRlcGVuZHMgb24gVklSVElPCmRpZmYgLS1naXQg YS9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZSBiL2RyaXZlcnMvdmlydGlvL01ha2VmaWxlCmluZGV4 IDNhMmI1YzVkY2Y0Ni4uZjI5OTdiNmM4MTJmIDEwMDY0NAotLS0gYS9kcml2ZXJzL3ZpcnRpby9N YWtlZmlsZQorKysgYi9kcml2ZXJzL3ZpcnRpby9NYWtlZmlsZQpAQCAtNiwzICs2LDQgQEAgdmly dGlvX3BjaS15IDo9IHZpcnRpb19wY2lfbW9kZXJuLm8gdmlydGlvX3BjaV9jb21tb24ubwogdmly dGlvX3BjaS0kKENPTkZJR19WSVJUSU9fUENJX0xFR0FDWSkgKz0gdmlydGlvX3BjaV9sZWdhY3ku bwogb2JqLSQoQ09ORklHX1ZJUlRJT19CQUxMT09OKSArPSB2aXJ0aW9fYmFsbG9vbi5vCiBvYmot JChDT05GSUdfVklSVElPX0lOUFVUKSArPSB2aXJ0aW9faW5wdXQubworb2JqLSQoQ09ORklHX1ZJ UlRJT19NREVWKSArPSB2aXJ0aW9fbWRldi5vCmRpZmYgLS1naXQgYS9kcml2ZXJzL3ZpcnRpby92 aXJ0aW9fbWRldi5jIGIvZHJpdmVycy92aXJ0aW8vdmlydGlvX21kZXYuYwpuZXcgZmlsZSBtb2Rl IDEwMDY0NAppbmRleCAwMDAwMDAwMDAwMDAuLjdmZGI0MmYwNTVkZgotLS0gL2Rldi9udWxsCisr KyBiL2RyaXZlcnMvdmlydGlvL3ZpcnRpb19tZGV2LmMKQEAgLTAsMCArMSw0MDkgQEAKKy8vIFNQ RFgtTGljZW5zZS1JZGVudGlmaWVyOiBHUEwtMi4wLW9ubHkKKy8qCisgKiBWSVJUSU8gYmFzZWQg ZHJpdmVyIGZvciBNZWRpYXRlZCBkZXZpY2UKKyAqCisgKiBDb3B5cmlnaHQgKGMpIDIwMTksIFJl ZCBIYXQuIEFsbCByaWdodHMgcmVzZXJ2ZWQuCisgKiAgICAgQXV0aG9yOiBKYXNvbiBXYW5nIDxq YXNvd2FuZ0ByZWRoYXQuY29tPgorICoKKyAqLworCisjaW5jbHVkZSA8bGludXgvaW5pdC5oPgor I2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgorI2luY2x1ZGUgPGxpbnV4L2RldmljZS5oPgorI2lu Y2x1ZGUgPGxpbnV4L2tlcm5lbC5oPgorI2luY2x1ZGUgPGxpbnV4L3NsYWIuaD4KKyNpbmNsdWRl IDxsaW51eC91dWlkLmg+CisjaW5jbHVkZSA8bGludXgvdmlydGlvLmg+CisjaW5jbHVkZSA8bGlu dXgvbWRldl92aXJ0aW8uaD4KKyNpbmNsdWRlIDxsaW51eC92aXJ0aW9fY29uZmlnLmg+CisjaW5j bHVkZSA8bGludXgvdmlydGlvX3JpbmcuaD4KKworI2RlZmluZSBEUklWRVJfVkVSU0lPTiAgIjAu MSIKKyNkZWZpbmUgRFJJVkVSX0FVVEhPUiAgICJSZWQgSGF0IENvcnBvcmF0aW9uIgorI2RlZmlu ZSBEUklWRVJfREVTQyAgICAgIlZJUlRJTyBiYXNlZCBkcml2ZXIgZm9yIE1lZGlhdGVkIGRldmlj ZSIKKworI2RlZmluZSB0b192aXJ0aW9fbWRldl9kZXZpY2UoZGV2KSBcCisJY29udGFpbmVyX29m KGRldiwgc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSwgdmRldikKKworc3RydWN0IHZpcnRpb19t ZGV2X2RldmljZSB7CisJc3RydWN0IHZpcnRpb19kZXZpY2UgdmRldjsKKwlzdHJ1Y3QgbWRldl9k ZXZpY2UgKm1kZXY7CisJdTY0IGZlYXR1cmVzOworCisJLyogVGhlIGxvY2sgdG8gcHJvdGVjdCB2 aXJ0cXVldWUgbGlzdCAqLworCXNwaW5sb2NrX3QgbG9jazsKKwkvKiBMaXN0IG9mIHZpcnRpb19t ZGV2X3ZxX2luZm8gKi8KKwlzdHJ1Y3QgbGlzdF9oZWFkIHZpcnRxdWV1ZXM7Cit9OworCitzdHJ1 Y3QgdmlydGlvX21kZXZfdnFfaW5mbyB7CisJLyogdGhlIGFjdHVhbCB2aXJ0cXVldWUgKi8KKwlz dHJ1Y3QgdmlydHF1ZXVlICp2cTsKKworCS8qIHRoZSBsaXN0IG5vZGUgZm9yIHRoZSB2aXJ0cXVl dWVzIGxpc3QgKi8KKwlzdHJ1Y3QgbGlzdF9oZWFkIG5vZGU7Cit9OworCitzdGF0aWMgc3RydWN0 IG1kZXZfZGV2aWNlICp2bV9nZXRfbWRldihzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sK KwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2aWNlICp2bV9kZXYgPSB0b192aXJ0aW9fbWRldl9kZXZp Y2UodmRldik7CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZGV2LT5tZGV2OworCisJ cmV0dXJuIG1kZXY7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X2dldChzdHJ1Y3Qgdmly dGlvX2RldmljZSAqdmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJICAgIHZvaWQgKmJ1ZiwgdW5z aWduZWQgbGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZk ZXYpOworCWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dl dF9vcHMobWRldik7CisKKwlvcHMtPmdldF9jb25maWcobWRldiwgb2Zmc2V0LCBidWYsIGxlbik7 Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3NldChzdHJ1Y3QgdmlydGlvX2RldmljZSAq dmRldiwgdW5zaWduZWQgb2Zmc2V0LAorCQkJICAgIGNvbnN0IHZvaWQgKmJ1ZiwgdW5zaWduZWQg bGVuKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOwor CWNvbnN0IHN0cnVjdCBtZGV2X3ZpcnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dldF9vcHMo bWRldik7CisKKwlvcHMtPnNldF9jb25maWcobWRldiwgb2Zmc2V0LCBidWYsIGxlbik7Cit9CisK K3N0YXRpYyB1MzIgdmlydGlvX21kZXZfZ2VuZXJhdGlvbihzdHJ1Y3QgdmlydGlvX2RldmljZSAq dmRldikKK3sKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsK Kwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3Bz KG1kZXYpOworCisKKwlpZiAob3BzLT5nZXRfZ2VuZXJhdGlvbikKKwkJcmV0dXJuIG9wcy0+Z2V0 X2dlbmVyYXRpb24obWRldik7CisKKwlyZXR1cm4gMDsKK30KKworc3RhdGljIHU4IHZpcnRpb19t ZGV2X2dldF9zdGF0dXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3RydWN0IG1k ZXZfZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3RydWN0IG1kZXZf dmlydGlvX29wcyAqb3BzID0gbWRldl92aXJ0aW9fZ2V0X29wcyhtZGV2KTsKKworCXJldHVybiBv cHMtPmdldF9zdGF0dXMobWRldik7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3NldF9z dGF0dXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYsIHU4IHN0YXR1cykKK3sKKwlzdHJ1Y3Qg bWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRl dl92aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJcmV0dXJu IG9wcy0+c2V0X3N0YXR1cyhtZGV2LCBzdGF0dXMpOworfQorCitzdGF0aWMgdm9pZCB2aXJ0aW9f bWRldl9yZXNldChzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRldl9k ZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0 aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJcmV0dXJuIG9wcy0+ c2V0X3N0YXR1cyhtZGV2LCAwKTsKK30KKworc3RhdGljIGJvb2wgdmlydGlvX21kZXZfbm90aWZ5 KHN0cnVjdCB2aXJ0cXVldWUgKnZxKQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZt X2dldF9tZGV2KHZxLT52ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fb3BzICpvcHMg PSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJb3BzLT5raWNrX3ZxKG1kZXYsIHZxLT5p bmRleCk7CisKKwlyZXR1cm4gdHJ1ZTsKK30KKworc3RhdGljIGlycXJldHVybl90IHZpcnRpb19t ZGV2X2NvbmZpZ19jYih2b2lkICpwcml2YXRlKQoreworCXN0cnVjdCB2aXJ0aW9fbWRldl9kZXZp Y2UgKnZtX2RldiA9IHByaXZhdGU7CisKKwl2aXJ0aW9fY29uZmlnX2NoYW5nZWQoJnZtX2Rldi0+ dmRldik7CisKKwlyZXR1cm4gSVJRX0hBTkRMRUQ7Cit9CisKK3N0YXRpYyBpcnFyZXR1cm5fdCB2 aXJ0aW9fbWRldl92aXJ0cXVldWVfY2Iodm9pZCAqcHJpdmF0ZSkKK3sKKwlzdHJ1Y3QgdmlydGlv X21kZXZfdnFfaW5mbyAqaW5mbyA9IHByaXZhdGU7CisKKwlyZXR1cm4gdnJpbmdfaW50ZXJydXB0 KDAsIGluZm8tPnZxKTsKK30KKworc3RhdGljIHN0cnVjdCB2aXJ0cXVldWUgKgordmlydGlvX21k ZXZfc2V0dXBfdnEoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYsIHVuc2lnbmVkIGludCBpbmRl eCwKKwkJICAgICB2b2lkICgqY2FsbGJhY2spKHN0cnVjdCB2aXJ0cXVldWUgKnZxKSwKKwkJICAg ICBjb25zdCBjaGFyICpuYW1lLCBib29sIGN0eCkKK3sKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlICp2bV9kZXYgPSB0b192aXJ0aW9fbWRldl9kZXZpY2UodmRldik7CisJc3RydWN0IG1kZXZf ZGV2aWNlICptZGV2ID0gdm1fZ2V0X21kZXYodmRldik7CisJY29uc3Qgc3RydWN0IG1kZXZfdmly dGlvX29wcyAqb3BzID0gbWRldl92aXJ0aW9fZ2V0X29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlv X21kZXZfdnFfaW5mbyAqaW5mbzsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfY2FsbGJhY2sgY2I7CisJ c3RydWN0IHZpcnRxdWV1ZSAqdnE7CisJdTY0IGRlc2NfYWRkciwgZHJpdmVyX2FkZHIsIGRldmlj ZV9hZGRyOworCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CisJdTMyIGFsaWduLCBudW07CisJaW50IGVy cjsKKworCWlmICghbmFtZSkKKwkJcmV0dXJuIE5VTEw7CisKKwkvKiBRdWV1ZSBzaG91bGRuJ3Qg YWxyZWFkeSBiZSBzZXQgdXAuICovCisJaWYgKG9wcy0+Z2V0X3ZxX3JlYWR5KG1kZXYsIGluZGV4 KSkKKwkJcmV0dXJuIEVSUl9QVFIoLUVOT0VOVCk7CisKKwkvKiBBbGxvY2F0ZSBhbmQgZmlsbCBv dXQgb3VyIGFjdGl2ZSBxdWV1ZSBkZXNjcmlwdGlvbiAqLworCWluZm8gPSBrbWFsbG9jKHNpemVv ZigqaW5mbyksIEdGUF9LRVJORUwpOworCWlmICghaW5mbykKKwkJcmV0dXJuIEVSUl9QVFIoLUVO T01FTSk7CisKKwludW0gPSBvcHMtPmdldF92cV9udW1fbWF4KG1kZXYpOworCWlmIChudW0gPT0g MCkgeworCQllcnIgPSAtRU5PRU5UOworCQlnb3RvIGVycm9yX25ld192aXJ0cXVldWU7CisJfQor CisJLyogQ3JlYXRlIHRoZSB2cmluZyAqLworCWFsaWduID0gb3BzLT5nZXRfdnFfYWxpZ24obWRl dik7CisJdnEgPSB2cmluZ19jcmVhdGVfdmlydHF1ZXVlKGluZGV4LCBudW0sIGFsaWduLCB2ZGV2 LAorCQkJCSAgICB0cnVlLCB0cnVlLCBjdHgsCisJCQkJICAgIHZpcnRpb19tZGV2X25vdGlmeSwg Y2FsbGJhY2ssIG5hbWUpOworCWlmICghdnEpIHsKKwkJZXJyID0gLUVOT01FTTsKKwkJZ290byBl cnJvcl9uZXdfdmlydHF1ZXVlOworCX0KKworCS8qIFNldHVwIHZpcnRxdWV1ZSBjYWxsYmFjayAq LworCWNiLmNhbGxiYWNrID0gdmlydGlvX21kZXZfdmlydHF1ZXVlX2NiOworCWNiLnByaXZhdGUg PSBpbmZvOworCW9wcy0+c2V0X3ZxX2NiKG1kZXYsIGluZGV4LCAmY2IpOworCW9wcy0+c2V0X3Zx X251bShtZGV2LCBpbmRleCwgdmlydHF1ZXVlX2dldF92cmluZ19zaXplKHZxKSk7CisKKwlkZXNj X2FkZHIgPSB2aXJ0cXVldWVfZ2V0X2Rlc2NfYWRkcih2cSk7CisJZHJpdmVyX2FkZHIgPSB2aXJ0 cXVldWVfZ2V0X2F2YWlsX2FkZHIodnEpOworCWRldmljZV9hZGRyID0gdmlydHF1ZXVlX2dldF91 c2VkX2FkZHIodnEpOworCisJaWYgKG9wcy0+c2V0X3ZxX2FkZHJlc3MobWRldiwgaW5kZXgsCisJ CQkJZGVzY19hZGRyLCBkcml2ZXJfYWRkciwKKwkJCQlkZXZpY2VfYWRkcikpIHsKKwkJZXJyID0g LUVJTlZBTDsKKwkJZ290byBlcnJfdnE7CisJfQorCisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwg aW5kZXgsIDEpOworCisJdnEtPnByaXYgPSBpbmZvOworCWluZm8tPnZxID0gdnE7CisKKwlzcGlu X2xvY2tfaXJxc2F2ZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisJbGlzdF9hZGQoJmluZm8tPm5v ZGUsICZ2bV9kZXYtPnZpcnRxdWV1ZXMpOworCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJnZtX2Rl di0+bG9jaywgZmxhZ3MpOworCisJcmV0dXJuIHZxOworCitlcnJfdnE6CisJdnJpbmdfZGVsX3Zp cnRxdWV1ZSh2cSk7CitlcnJvcl9uZXdfdmlydHF1ZXVlOgorCW9wcy0+c2V0X3ZxX3JlYWR5KG1k ZXYsIGluZGV4LCAwKTsKKwlXQVJOX09OKG9wcy0+Z2V0X3ZxX3JlYWR5KG1kZXYsIGluZGV4KSk7 CisJa2ZyZWUoaW5mbyk7CisJcmV0dXJuIEVSUl9QVFIoZXJyKTsKK30KKworc3RhdGljIHZvaWQg dmlydGlvX21kZXZfZGVsX3ZxKHN0cnVjdCB2aXJ0cXVldWUgKnZxKQoreworCXN0cnVjdCB2aXJ0 aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2RldmljZSh2cS0+dmRldik7 CisJc3RydWN0IG1kZXZfZGV2aWNlICptZGV2ID0gdm1fZGV2LT5tZGV2OworCWNvbnN0IHN0cnVj dCBtZGV2X3ZpcnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dldF9vcHMobWRldik7CisJc3Ry dWN0IHZpcnRpb19tZGV2X3ZxX2luZm8gKmluZm8gPSB2cS0+cHJpdjsKKwl1bnNpZ25lZCBpbnQg aW5kZXggPSB2cS0+aW5kZXg7CisJdW5zaWduZWQgbG9uZyBmbGFnczsKKworCXNwaW5fbG9ja19p cnFzYXZlKCZ2bV9kZXYtPmxvY2ssIGZsYWdzKTsKKwlsaXN0X2RlbCgmaW5mby0+bm9kZSk7CisJ c3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmdm1fZGV2LT5sb2NrLCBmbGFncyk7CisKKwkvKiBTZWxl Y3QgYW5kIGRlYWN0aXZhdGUgdGhlIHF1ZXVlICovCisJb3BzLT5zZXRfdnFfcmVhZHkobWRldiwg aW5kZXgsIDApOworCVdBUk5fT04ob3BzLT5nZXRfdnFfcmVhZHkobWRldiwgaW5kZXgpKTsKKwor CXZyaW5nX2RlbF92aXJ0cXVldWUodnEpOworCisJa2ZyZWUoaW5mbyk7Cit9CisKK3N0YXRpYyB2 b2lkIHZpcnRpb19tZGV2X2RlbF92cXMoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJ c3RydWN0IHZpcnRxdWV1ZSAqdnEsICpuOworCisJbGlzdF9mb3JfZWFjaF9lbnRyeV9zYWZlKHZx LCBuLCAmdmRldi0+dnFzLCBsaXN0KQorCQl2aXJ0aW9fbWRldl9kZWxfdnEodnEpOworfQorCitz dGF0aWMgaW50IHZpcnRpb19tZGV2X2ZpbmRfdnFzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2 LCB1bnNpZ25lZCBudnFzLAorCQkJCXN0cnVjdCB2aXJ0cXVldWUgKnZxc1tdLAorCQkJCXZxX2Nh bGxiYWNrX3QgKmNhbGxiYWNrc1tdLAorCQkJCWNvbnN0IGNoYXIgKiBjb25zdCBuYW1lc1tdLAor CQkJCWNvbnN0IGJvb2wgKmN0eCwKKwkJCQlzdHJ1Y3QgaXJxX2FmZmluaXR5ICpkZXNjKQorewor CXN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UgKnZtX2RldiA9IHRvX3ZpcnRpb19tZGV2X2Rldmlj ZSh2ZGV2KTsKKwlzdHJ1Y3QgbWRldl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsK Kwljb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3Bz KG1kZXYpOworCXN0cnVjdCB2aXJ0aW9fbWRldl9jYWxsYmFjayBjYjsKKwlpbnQgaSwgZXJyLCBx dWV1ZV9pZHggPSAwOworCisJZm9yIChpID0gMDsgaSA8IG52cXM7ICsraSkgeworCQlpZiAoIW5h bWVzW2ldKSB7CisJCQl2cXNbaV0gPSBOVUxMOworCQkJY29udGludWU7CisJCX0KKworCQl2cXNb aV0gPSB2aXJ0aW9fbWRldl9zZXR1cF92cSh2ZGV2LCBxdWV1ZV9pZHgrKywKKwkJCQkJICAgICAg Y2FsbGJhY2tzW2ldLCBuYW1lc1tpXSwgY3R4ID8KKwkJCQkJICAgICAgY3R4W2ldIDogZmFsc2Up OworCQlpZiAoSVNfRVJSKHZxc1tpXSkpIHsKKwkJCWVyciA9IFBUUl9FUlIodnFzW2ldKTsKKwkJ CWdvdG8gZXJyX3NldHVwX3ZxOworCQl9CisJfQorCisJY2IuY2FsbGJhY2sgPSB2aXJ0aW9fbWRl dl9jb25maWdfY2I7CisJY2IucHJpdmF0ZSA9IHZtX2RldjsKKwlvcHMtPnNldF9jb25maWdfY2Io bWRldiwgJmNiKTsKKworCXJldHVybiAwOworCitlcnJfc2V0dXBfdnE6CisJdmlydGlvX21kZXZf ZGVsX3Zxcyh2ZGV2KTsKKwlyZXR1cm4gZXJyOworfQorCitzdGF0aWMgdTY0IHZpcnRpb19tZGV2 X2dldF9mZWF0dXJlcyhzdHJ1Y3QgdmlydGlvX2RldmljZSAqdmRldikKK3sKKwlzdHJ1Y3QgbWRl dl9kZXZpY2UgKm1kZXYgPSB2bV9nZXRfbWRldih2ZGV2KTsKKwljb25zdCBzdHJ1Y3QgbWRldl92 aXJ0aW9fb3BzICpvcHMgPSBtZGV2X3ZpcnRpb19nZXRfb3BzKG1kZXYpOworCisJcmV0dXJuIG9w cy0+Z2V0X2ZlYXR1cmVzKG1kZXYpOworfQorCitzdGF0aWMgaW50IHZpcnRpb19tZGV2X2ZpbmFs aXplX2ZlYXR1cmVzKHN0cnVjdCB2aXJ0aW9fZGV2aWNlICp2ZGV2KQoreworCXN0cnVjdCBtZGV2 X2RldmljZSAqbWRldiA9IHZtX2dldF9tZGV2KHZkZXYpOworCWNvbnN0IHN0cnVjdCBtZGV2X3Zp cnRpb19vcHMgKm9wcyA9IG1kZXZfdmlydGlvX2dldF9vcHMobWRldik7CisKKwkvKiBHaXZlIHZp cnRpb19yaW5nIGEgY2hhbmNlIHRvIGFjY2VwdCBmZWF0dXJlcy4gKi8KKwl2cmluZ190cmFuc3Bv cnRfZmVhdHVyZXModmRldik7CisKKwlyZXR1cm4gb3BzLT5zZXRfZmVhdHVyZXMobWRldiwgdmRl di0+ZmVhdHVyZXMpOworfQorCitzdGF0aWMgY29uc3QgY2hhciAqdmlydGlvX21kZXZfYnVzX25h bWUoc3RydWN0IHZpcnRpb19kZXZpY2UgKnZkZXYpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2Rl dmljZSAqdm1fZGV2ID0gdG9fdmlydGlvX21kZXZfZGV2aWNlKHZkZXYpOworCXN0cnVjdCBtZGV2 X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsKKworCXJldHVybiBkZXZfbmFtZShtZGV2X2Rl dihtZGV2KSk7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3QgdmlydGlvX2NvbmZpZ19vcHMgdmly dGlvX21kZXZfY29uZmlnX29wcyA9IHsKKwkuZ2V0CQk9IHZpcnRpb19tZGV2X2dldCwKKwkuc2V0 CQk9IHZpcnRpb19tZGV2X3NldCwKKwkuZ2VuZXJhdGlvbgk9IHZpcnRpb19tZGV2X2dlbmVyYXRp b24sCisJLmdldF9zdGF0dXMJPSB2aXJ0aW9fbWRldl9nZXRfc3RhdHVzLAorCS5zZXRfc3RhdHVz CT0gdmlydGlvX21kZXZfc2V0X3N0YXR1cywKKwkucmVzZXQJCT0gdmlydGlvX21kZXZfcmVzZXQs CisJLmZpbmRfdnFzCT0gdmlydGlvX21kZXZfZmluZF92cXMsCisJLmRlbF92cXMJPSB2aXJ0aW9f bWRldl9kZWxfdnFzLAorCS5nZXRfZmVhdHVyZXMJPSB2aXJ0aW9fbWRldl9nZXRfZmVhdHVyZXMs CisJLmZpbmFsaXplX2ZlYXR1cmVzID0gdmlydGlvX21kZXZfZmluYWxpemVfZmVhdHVyZXMsCisJ LmJ1c19uYW1lCT0gdmlydGlvX21kZXZfYnVzX25hbWUsCit9OworCitzdGF0aWMgdm9pZCB2aXJ0 aW9fbWRldl9yZWxlYXNlX2RldihzdHJ1Y3QgZGV2aWNlICpfZCkKK3sKKwlzdHJ1Y3QgdmlydGlv X2RldmljZSAqdmRldiA9CisJICAgICAgIGNvbnRhaW5lcl9vZihfZCwgc3RydWN0IHZpcnRpb19k ZXZpY2UsIGRldik7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2ID0KKwkgICAg ICAgY29udGFpbmVyX29mKHZkZXYsIHN0cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UsIHZkZXYpOwor CXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IHZtX2Rldi0+bWRldjsKKworCWRldm1fa2ZyZWUo bWRldl9kZXYobWRldiksIHZtX2Rldik7Cit9CisKK3N0YXRpYyBpbnQgdmlydGlvX21kZXZfcHJv YmUoc3RydWN0IGRldmljZSAqZGV2KQoreworCXN0cnVjdCBtZGV2X2RldmljZSAqbWRldiA9IG1k ZXZfdmlydGlvX2Zyb21fZGV2KGRldik7CisJY29uc3Qgc3RydWN0IG1kZXZfdmlydGlvX29wcyAq b3BzID0gbWRldl92aXJ0aW9fZ2V0X29wcyhtZGV2KTsKKwlzdHJ1Y3QgdmlydGlvX21kZXZfZGV2 aWNlICp2bV9kZXY7CisJaW50IHJjOworCisJdm1fZGV2ID0gZGV2bV9remFsbG9jKGRldiwgc2l6 ZW9mKCp2bV9kZXYpLCBHRlBfS0VSTkVMKTsKKwlpZiAoIXZtX2RldikKKwkJcmV0dXJuIC1FTk9N RU07CisKKwl2bV9kZXYtPnZkZXYuZGV2LnBhcmVudCA9IGRldjsKKwl2bV9kZXYtPnZkZXYuZGV2 LnJlbGVhc2UgPSB2aXJ0aW9fbWRldl9yZWxlYXNlX2RldjsKKwl2bV9kZXYtPnZkZXYuY29uZmln ID0gJnZpcnRpb19tZGV2X2NvbmZpZ19vcHM7CisJdm1fZGV2LT5tZGV2ID0gbWRldjsKKwlJTklU X0xJU1RfSEVBRCgmdm1fZGV2LT52aXJ0cXVldWVzKTsKKwlzcGluX2xvY2tfaW5pdCgmdm1fZGV2 LT5sb2NrKTsKKworCXZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPSBvcHMtPmdldF9kZXZpY2VfaWQo bWRldik7CisJaWYgKHZtX2Rldi0+dmRldi5pZC5kZXZpY2UgPT0gMCkKKwkJcmV0dXJuIC1FTk9E RVY7CisKKwl2bV9kZXYtPnZkZXYuaWQudmVuZG9yID0gb3BzLT5nZXRfdmVuZG9yX2lkKG1kZXYp OworCXJjID0gcmVnaXN0ZXJfdmlydGlvX2RldmljZSgmdm1fZGV2LT52ZGV2KTsKKwlpZiAocmMp CisJCXB1dF9kZXZpY2UoZGV2KTsKKwllbHNlCisJCWRldl9zZXRfZHJ2ZGF0YShkZXYsIHZtX2Rl dik7CisKKwlyZXR1cm4gcmM7Cit9CisKK3N0YXRpYyB2b2lkIHZpcnRpb19tZGV2X3JlbW92ZShz dHJ1Y3QgZGV2aWNlICpkZXYpCit7CisJc3RydWN0IHZpcnRpb19tZGV2X2RldmljZSAqdm1fZGV2 ID0gZGV2X2dldF9kcnZkYXRhKGRldik7CisKKwl1bnJlZ2lzdGVyX3ZpcnRpb19kZXZpY2UoJnZt X2Rldi0+dmRldik7Cit9CisKK3N0YXRpYyBjb25zdCBzdHJ1Y3QgbWRldl92aXJ0aW9fY2xhc3Nf aWQgdmlydGlvX2lkX3RhYmxlW10gPSB7CisJeyBNREVWX1ZJUlRJT19DTEFTU19JRF9WSVJUSU8g fSwKKwl7IDAgfSwKK307CisKK01PRFVMRV9ERVZJQ0VfVEFCTEUobWRldl92aXJ0aW8sIHZpcnRp b19pZF90YWJsZSk7CisKK3N0YXRpYyBzdHJ1Y3QgbWRldl92aXJ0aW9fZHJpdmVyIHZpcnRpb19t ZGV2X2RyaXZlciA9IHsKKwkuZHJ2ID0geworCQkubmFtZQk9ICJ2aXJ0aW9fbWRldiIsCisJCS5w cm9iZQk9IHZpcnRpb19tZGV2X3Byb2JlLAorCQkucmVtb3ZlID0gdmlydGlvX21kZXZfcmVtb3Zl LAorCX0sCisJLmlkX3RhYmxlID0gdmlydGlvX2lkX3RhYmxlLAorfTsKKworc3RhdGljIGludCBf X2luaXQgdmlydGlvX21kZXZfaW5pdCh2b2lkKQoreworCXJldHVybiBtZGV2X3JlZ2lzdGVyX2Ry aXZlcigmdmlydGlvX21kZXZfZHJpdmVyLmRydiwgVEhJU19NT0RVTEUsCisJCQkJICAgICZtZGV2 X3ZpcnRpb19idXNfdHlwZSk7Cit9CisKK3N0YXRpYyB2b2lkIF9fZXhpdCB2aXJ0aW9fbWRldl9l eGl0KHZvaWQpCit7CisJbWRldl91bnJlZ2lzdGVyX2RyaXZlcigmdmlydGlvX21kZXZfZHJpdmVy LmRydik7Cit9CisKK21vZHVsZV9pbml0KHZpcnRpb19tZGV2X2luaXQpCittb2R1bGVfZXhpdCh2 aXJ0aW9fbWRldl9leGl0KQorCitNT0RVTEVfVkVSU0lPTihEUklWRVJfVkVSU0lPTik7CitNT0RV TEVfTElDRU5TRSgiR1BMIHYyIik7CitNT0RVTEVfQVVUSE9SKERSSVZFUl9BVVRIT1IpOworTU9E VUxFX0RFU0NSSVBUSU9OKERSSVZFUl9ERVNDKTsKZGlmZiAtLWdpdCBhL2luY2x1ZGUvbGludXgv bWRldl92aXJ0aW8uaCBiL2luY2x1ZGUvbGludXgvbWRldl92aXJ0aW8uaAppbmRleCBlZjJkYmI2 YzM4M2EuLjVmNzVmM2NmNTllMSAxMDA2NDQKLS0tIGEvaW5jbHVkZS9saW51eC9tZGV2X3ZpcnRp by5oCisrKyBiL2luY2x1ZGUvbGludXgvbWRldl92aXJ0aW8uaApAQCAtMjUsNiArMjUsMTEgQEAg c3RydWN0IHZpcnRpb19tZGV2X2NhbGxiYWNrIHsKIAl2b2lkICpwcml2YXRlOwogfTsKIAorZW51 bSB7CisJTURFVl9WSVJUSU9fQ0xBU1NfSURfVklSVElPID0gMSwKKwkvKiBOZXcgZW50cmllcyBt dXN0IGJlIGFkZGVkIGhlcmUgKi8KK307CisKIC8qKgogICogc3RydWN0IG1kZXZfdmlydGlvX2Rl dmljZV9vcHMgLSBTdHJ1Y3R1cmUgdG8gYmUgcmVnaXN0ZXJlZCBmb3IgZWFjaAogICogbWRldiBk ZXZpY2UgdG8gcmVnaXN0ZXIgdGhlIGRldmljZSBmb3IgdmlydGlvL3Zob3N0IGRyaXZlcnMuCi0t IAoyLjE5LjEKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f CkludGVsLWdmeCBtYWlsaW5nIGxpc3QKSW50ZWwtZ2Z4QGxpc3RzLmZyZWVkZXNrdG9wLm9yZwpo dHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2ludGVsLWdmeA==