From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mx1.redhat.com ([209.132.183.28]:39608 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726800AbfKGJBY (ORCPT ); Thu, 7 Nov 2019 04:01:24 -0500 Received: from mail-qk1-f197.google.com (mail-qk1-f197.google.com [209.85.222.197]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 73C035945B for ; Thu, 7 Nov 2019 09:01:23 +0000 (UTC) Received: by mail-qk1-f197.google.com with SMTP id q29so1499861qkn.3 for ; Thu, 07 Nov 2019 01:01:23 -0800 (PST) Date: Thu, 7 Nov 2019 04:01:09 -0500 From: "Michael S. Tsirkin" Subject: Re: [PATCH V9 0/6] mdev based hardware virtio offloading support Message-ID: <20191107040055-mutt-send-email-mst@kernel.org> References: <20191106070548.18980-1-jasowang@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20191106070548.18980-1-jasowang@redhat.com> Sender: linux-s390-owner@vger.kernel.org List-ID: To: Jason Wang Cc: 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, tiwei.bie@intel.com, 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 On Wed, Nov 06, 2019 at 03:05:42PM +0800, Jason Wang wrote: > Hi all: > > There are hardwares that can do virtio datapath offloading while > having its own control path. This path tries to implement a mdev based > unified API to support using kernel virtio driver to drive those > devices. This is done by introducing a new mdev transport for virtio > (virtio_mdev) and register itself as a new kind of mdev driver. Then > it provides a unified way for kernel virtio driver to talk with mdev > device implementation. > > Though the series only contains kernel driver support, the goal is to > make the transport generic enough to support userspace drivers. This > means vhost-mdev[1] could be built on top as well by resuing the > transport. > > A sample driver is also implemented which simulate a virito-net > loopback ethernet device on top of vringh + workqueue. This could be > used as a reference implementation for real hardware driver. > > Also a real IFC VF driver was also posted here[2] which is a good > reference for vendors who is interested in their own virtio datapath > offloading product. > > Consider mdev framework only support VFIO device and driver right now, > this series also extend it to support other types. This is done > through introducing class id to the device and pairing it with > id_talbe claimed by the driver. On top, this seris also decouple > device specific parents ops out of the common ones. > > Pktgen test was done with virito-net + mvnet loop back device. > > Please review. > > [1] https://lkml.org/lkml/2019/11/5/424 > [2] https://lkml.org/lkml/2019/11/5/227 Series: Acked-by: Michael S. Tsirkin > Changes from V8: > - try silent checkpatch, some are still there becuase they were inherited > from virtio_config_ops which needs to be resolved in an independent series > - tweak on the comment and doc > - remove VIRTIO_MDEV_F_VERSION_1 completely > - rename CONFIG_VIRTIO_MDEV_DEVICE to CONFIG_VIRTIO_MDEV > > Changes from V7: > - drop {set|get}_mdev_features for virtio > - typo and comment style fixes > > Changes from V6: > - rename ops files and compile guard > > Changes from V5: > - use dev_warn() instead of WARN(1) when class id is not set > - validate id_table before trying to do matching between device and > driver > - add wildcard for modpost script > - use unique name for id_table > - move get_mdev_features() to be the first member of virtio_device_ops > and more comments for it > - typo fixes for the comments above virtio_mdev_ops > > Changes from V4: > - keep mdev_set_class() for the device that doesn't use device ops > - use union for device ops pointer in mdev_device > - introduce class specific helper for getting is device ops > - use WARN_ON instead of BUG_ON in mdev_set_virtio_ops > - explain details of get_mdev_features() and get_vendor_id() > - distinguish the optional virito device ops from mandatory ones and > make get_generation() optional > - rename vfio_mdev.h to vfio_mdev_ops.h, rename virito_mdev.h to > virtio_mdev_ops.h > - don't abuse version fileds in virtio_mdev structure, use features > instead > - fix warning during device remove > - style & docs tweaks and typo fixes > > Changes from V3: > - document that class id (device ops) must be specified in create() > - add WARN() when trying to set class_id when it has already set > - add WARN() when class_id is not specified in create() and correctly > return an error in this case > - correct the prototype of mdev_set_class() in the doc > - add documention of mdev_set_class() > - remove the unnecessary "class_id_fail" label when class id is not > specified in create() > - convert id_table in vfio_mdev to const > - move mdev_set_class and its friends after mdev_uuid() > - suqash the patch of bus uevent into patch of introducing class id > - tweak the words in the docs per Cornelia suggestion > - tie class_id and device ops through class specific initialization > routine like mdev_set_vfio_ops() > - typos fixes in the docs of virtio-mdev callbacks > - document the usage of virtqueues in struct virtio_mdev_device > - remove the useless vqs array in struct virtio_mdev_device > - rename MDEV_ID_XXX to MDEV_CLASS_ID_XXX > > Changes from V2: > - fail when class_id is not specified > - drop the vringh patch > - match the doc to the code > - tweak the commit log > - move device_ops from parent to mdev device > - remove the unused MDEV_ID_VHOST > > Changes from V1: > - move virtio_mdev.c to drivers/virtio > - store class_id in mdev_device instead of mdev_parent > - store device_ops in mdev_device instead of mdev_parent > - reorder the patch, vringh fix comes first > - really silent compiling warnings > - really switch to use u16 for class_id > - uevent and modpost support for mdev class_id > - vraious tweaks per comments from Parav > > Changes from RFC-V2: > - silent compile warnings on some specific configuration > - use u16 instead u8 for class id > - reseve MDEV_ID_VHOST for future vhost-mdev work > - introduce "virtio" type for mvnet and make "vhost" type for future > work > - add entries in MAINTAINER > - tweak and typos fixes in commit log > > Changes from RFC-V1: > - rename device id to class id > - add docs for class id and device specific ops (device_ops) > - split device_ops into seperate headers > - drop the mdev_set_dma_ops() > - use device_ops to implement the transport API, then it's not a part > of UAPI any more > - use GFP_ATOMIC in mvnet sample device and other tweaks > - set_vring_base/get_vring_base support for mvnet device > > Jason Wang (6): > mdev: class id support > modpost: add support for mdev class id > mdev: introduce device specific ops > mdev: introduce virtio device and its device ops > virtio: introduce a mdev based transport > docs: sample driver to demonstrate how to implement virtio-mdev > framework > > .../driver-api/vfio-mediated-device.rst | 38 +- > MAINTAINERS | 3 + > drivers/gpu/drm/i915/gvt/kvmgt.c | 17 +- > drivers/s390/cio/vfio_ccw_ops.c | 17 +- > drivers/s390/crypto/vfio_ap_ops.c | 13 +- > drivers/vfio/mdev/mdev_core.c | 60 ++ > drivers/vfio/mdev/mdev_driver.c | 25 + > drivers/vfio/mdev/mdev_private.h | 8 + > drivers/vfio/mdev/vfio_mdev.c | 45 +- > drivers/virtio/Kconfig | 13 + > drivers/virtio/Makefile | 1 + > drivers/virtio/virtio_mdev.c | 406 +++++++++++ > include/linux/mdev.h | 57 +- > include/linux/mdev_vfio_ops.h | 52 ++ > include/linux/mdev_virtio_ops.h | 147 ++++ > include/linux/mod_devicetable.h | 8 + > samples/Kconfig | 10 + > samples/vfio-mdev/Makefile | 1 + > samples/vfio-mdev/mbochs.c | 19 +- > samples/vfio-mdev/mdpy.c | 19 +- > samples/vfio-mdev/mtty.c | 17 +- > samples/vfio-mdev/mvnet.c | 686 ++++++++++++++++++ > scripts/mod/devicetable-offsets.c | 3 + > scripts/mod/file2alias.c | 11 + > 24 files changed, 1585 insertions(+), 91 deletions(-) > create mode 100644 drivers/virtio/virtio_mdev.c > create mode 100644 include/linux/mdev_vfio_ops.h > create mode 100644 include/linux/mdev_virtio_ops.h > create mode 100644 samples/vfio-mdev/mvnet.c > > -- > 2.19.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Michael S. Tsirkin" Subject: Re: [PATCH V9 0/6] mdev based hardware virtio offloading support Date: Thu, 7 Nov 2019 04:01:09 -0500 Message-ID: <20191107040055-mutt-send-email-mst@kernel.org> References: <20191106070548.18980-1-jasowang@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20191106070548.18980-1-jasowang@redhat.com> Sender: linux-kernel-owner@vger.kernel.org To: Jason Wang Cc: 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, tiwei.bie@intel.com, 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.ib List-Id: dri-devel@lists.freedesktop.org On Wed, Nov 06, 2019 at 03:05:42PM +0800, Jason Wang wrote: > Hi all: > > There are hardwares that can do virtio datapath offloading while > having its own control path. This path tries to implement a mdev based > unified API to support using kernel virtio driver to drive those > devices. This is done by introducing a new mdev transport for virtio > (virtio_mdev) and register itself as a new kind of mdev driver. Then > it provides a unified way for kernel virtio driver to talk with mdev > device implementation. > > Though the series only contains kernel driver support, the goal is to > make the transport generic enough to support userspace drivers. This > means vhost-mdev[1] could be built on top as well by resuing the > transport. > > A sample driver is also implemented which simulate a virito-net > loopback ethernet device on top of vringh + workqueue. This could be > used as a reference implementation for real hardware driver. > > Also a real IFC VF driver was also posted here[2] which is a good > reference for vendors who is interested in their own virtio datapath > offloading product. > > Consider mdev framework only support VFIO device and driver right now, > this series also extend it to support other types. This is done > through introducing class id to the device and pairing it with > id_talbe claimed by the driver. On top, this seris also decouple > device specific parents ops out of the common ones. > > Pktgen test was done with virito-net + mvnet loop back device. > > Please review. > > [1] https://lkml.org/lkml/2019/11/5/424 > [2] https://lkml.org/lkml/2019/11/5/227 Series: Acked-by: Michael S. Tsirkin > Changes from V8: > - try silent checkpatch, some are still there becuase they were inherited > from virtio_config_ops which needs to be resolved in an independent series > - tweak on the comment and doc > - remove VIRTIO_MDEV_F_VERSION_1 completely > - rename CONFIG_VIRTIO_MDEV_DEVICE to CONFIG_VIRTIO_MDEV > > Changes from V7: > - drop {set|get}_mdev_features for virtio > - typo and comment style fixes > > Changes from V6: > - rename ops files and compile guard > > Changes from V5: > - use dev_warn() instead of WARN(1) when class id is not set > - validate id_table before trying to do matching between device and > driver > - add wildcard for modpost script > - use unique name for id_table > - move get_mdev_features() to be the first member of virtio_device_ops > and more comments for it > - typo fixes for the comments above virtio_mdev_ops > > Changes from V4: > - keep mdev_set_class() for the device that doesn't use device ops > - use union for device ops pointer in mdev_device > - introduce class specific helper for getting is device ops > - use WARN_ON instead of BUG_ON in mdev_set_virtio_ops > - explain details of get_mdev_features() and get_vendor_id() > - distinguish the optional virito device ops from mandatory ones and > make get_generation() optional > - rename vfio_mdev.h to vfio_mdev_ops.h, rename virito_mdev.h to > virtio_mdev_ops.h > - don't abuse version fileds in virtio_mdev structure, use features > instead > - fix warning during device remove > - style & docs tweaks and typo fixes > > Changes from V3: > - document that class id (device ops) must be specified in create() > - add WARN() when trying to set class_id when it has already set > - add WARN() when class_id is not specified in create() and correctly > return an error in this case > - correct the prototype of mdev_set_class() in the doc > - add documention of mdev_set_class() > - remove the unnecessary "class_id_fail" label when class id is not > specified in create() > - convert id_table in vfio_mdev to const > - move mdev_set_class and its friends after mdev_uuid() > - suqash the patch of bus uevent into patch of introducing class id > - tweak the words in the docs per Cornelia suggestion > - tie class_id and device ops through class specific initialization > routine like mdev_set_vfio_ops() > - typos fixes in the docs of virtio-mdev callbacks > - document the usage of virtqueues in struct virtio_mdev_device > - remove the useless vqs array in struct virtio_mdev_device > - rename MDEV_ID_XXX to MDEV_CLASS_ID_XXX > > Changes from V2: > - fail when class_id is not specified > - drop the vringh patch > - match the doc to the code > - tweak the commit log > - move device_ops from parent to mdev device > - remove the unused MDEV_ID_VHOST > > Changes from V1: > - move virtio_mdev.c to drivers/virtio > - store class_id in mdev_device instead of mdev_parent > - store device_ops in mdev_device instead of mdev_parent > - reorder the patch, vringh fix comes first > - really silent compiling warnings > - really switch to use u16 for class_id > - uevent and modpost support for mdev class_id > - vraious tweaks per comments from Parav > > Changes from RFC-V2: > - silent compile warnings on some specific configuration > - use u16 instead u8 for class id > - reseve MDEV_ID_VHOST for future vhost-mdev work > - introduce "virtio" type for mvnet and make "vhost" type for future > work > - add entries in MAINTAINER > - tweak and typos fixes in commit log > > Changes from RFC-V1: > - rename device id to class id > - add docs for class id and device specific ops (device_ops) > - split device_ops into seperate headers > - drop the mdev_set_dma_ops() > - use device_ops to implement the transport API, then it's not a part > of UAPI any more > - use GFP_ATOMIC in mvnet sample device and other tweaks > - set_vring_base/get_vring_base support for mvnet device > > Jason Wang (6): > mdev: class id support > modpost: add support for mdev class id > mdev: introduce device specific ops > mdev: introduce virtio device and its device ops > virtio: introduce a mdev based transport > docs: sample driver to demonstrate how to implement virtio-mdev > framework > > .../driver-api/vfio-mediated-device.rst | 38 +- > MAINTAINERS | 3 + > drivers/gpu/drm/i915/gvt/kvmgt.c | 17 +- > drivers/s390/cio/vfio_ccw_ops.c | 17 +- > drivers/s390/crypto/vfio_ap_ops.c | 13 +- > drivers/vfio/mdev/mdev_core.c | 60 ++ > drivers/vfio/mdev/mdev_driver.c | 25 + > drivers/vfio/mdev/mdev_private.h | 8 + > drivers/vfio/mdev/vfio_mdev.c | 45 +- > drivers/virtio/Kconfig | 13 + > drivers/virtio/Makefile | 1 + > drivers/virtio/virtio_mdev.c | 406 +++++++++++ > include/linux/mdev.h | 57 +- > include/linux/mdev_vfio_ops.h | 52 ++ > include/linux/mdev_virtio_ops.h | 147 ++++ > include/linux/mod_devicetable.h | 8 + > samples/Kconfig | 10 + > samples/vfio-mdev/Makefile | 1 + > samples/vfio-mdev/mbochs.c | 19 +- > samples/vfio-mdev/mdpy.c | 19 +- > samples/vfio-mdev/mtty.c | 17 +- > samples/vfio-mdev/mvnet.c | 686 ++++++++++++++++++ > scripts/mod/devicetable-offsets.c | 3 + > scripts/mod/file2alias.c | 11 + > 24 files changed, 1585 insertions(+), 91 deletions(-) > create mode 100644 drivers/virtio/virtio_mdev.c > create mode 100644 include/linux/mdev_vfio_ops.h > create mode 100644 include/linux/mdev_virtio_ops.h > create mode 100644 samples/vfio-mdev/mvnet.c > > -- > 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=-0.8 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=no 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 6A0BCFA372C for ; Thu, 7 Nov 2019 09:01:27 +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 4A3282187F for ; Thu, 7 Nov 2019 09:01:27 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 4A3282187F 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 B7FA46F396; Thu, 7 Nov 2019 09:01:25 +0000 (UTC) Received: from mx1.redhat.com (mx1.redhat.com [209.132.183.28]) by gabe.freedesktop.org (Postfix) with ESMTPS id 062E56F392 for ; Thu, 7 Nov 2019 09:01:24 +0000 (UTC) Received: from mail-qk1-f199.google.com (mail-qk1-f199.google.com [209.85.222.199]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 7151A859FE for ; Thu, 7 Nov 2019 09:01:23 +0000 (UTC) Received: by mail-qk1-f199.google.com with SMTP id 64so1487582qkm.5 for ; Thu, 07 Nov 2019 01:01:23 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=Iuf7pY0vuoI1H2ku5bfjNilR7JIa9xxrVrj3ZMN2r0I=; b=UA4ATZYoxtx/xgiPsVTJ5m/trg4yRMH3dUAbBG4WGuTX+z6xRpyHoFAbohvVobAROi i/o4qZZFYt5luSdY21Ft3nXUQtJpGXLEFaP9lyUuS02T1EVUyHSKGdMYNg+xomNgbCnO 2xtM7tLKA0ak54YwJyg1RZZsHdRfNIM06LAw6CBcn5be23KhTdNOdyGJrGKQInXfo2oW kLzQnIsj97L+BUggtALiblci0SCpz40aAJQeF6nBdZDhw8LT98DSQYTR6+m9/gTEHo6k sNCPzY6M46heoCXIIv4wNn+++6SY552i7eKGYab5dhUVKfrZU82C8i7Uj/L0WJ7O5Afx 7aNA== X-Gm-Message-State: APjAAAVs+VsXUKRCgmtYSKvMb9OdFuDaFi3yeEAFUopuXd2kXcSyVzc6 HqmJUmp6PWkjH9GbhW3RfZKkM8vI4bzkh18PtNg5j9MwAMhPx3vGLoAIf2mMID15PK/FBsSq5C8 vrIO9yIaxo0t8A7DA4fBSAX18flar X-Received: by 2002:a37:9d0:: with SMTP id 199mr1741253qkj.356.1573117282580; Thu, 07 Nov 2019 01:01:22 -0800 (PST) X-Google-Smtp-Source: APXvYqza6VsCEEQioEycCTS7IjmrN8FqLVHpcn7603qJAchUJjGf6blUNptyX48oixjHG7mtpq7G3A== X-Received: by 2002:a37:9d0:: with SMTP id 199mr1741203qkj.356.1573117282207; Thu, 07 Nov 2019 01:01:22 -0800 (PST) Received: from redhat.com (bzq-79-178-12-128.red.bezeqint.net. [79.178.12.128]) by smtp.gmail.com with ESMTPSA id o1sm958206qtb.82.2019.11.07.01.01.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Nov 2019 01:01:21 -0800 (PST) Date: Thu, 7 Nov 2019 04:01:09 -0500 From: "Michael S. Tsirkin" To: Jason Wang Subject: Re: [PATCH V9 0/6] mdev based hardware virtio offloading support Message-ID: <20191107040055-mutt-send-email-mst@kernel.org> References: <20191106070548.18980-1-jasowang@redhat.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20191106070548.18980-1-jasowang@redhat.com> 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: stefanha@redhat.com, christophe.de.dinechin@gmail.com, kvm@vger.kernel.org, airlied@linux.ie, heiko.carstens@de.ibm.com, kevin.tian@intel.com, dri-devel@lists.freedesktop.org, virtualization@lists.linux-foundation.org, kwankhede@nvidia.com, rob.miller@broadcom.com, linux-s390@vger.kernel.org, sebott@linux.ibm.com, lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com, borntraeger@de.ibm.com, haotian.wang@sifive.com, cunming.liang@intel.com, zhi.a.wang@intel.com, farman@linux.ibm.com, idos@mellanox.com, gor@linux.ibm.com, intel-gfx@lists.freedesktop.org, alex.williamson@redhat.com, xiao.w.wang@intel.com, freude@linux.ibm.com, parav@mellanox.com, zhihong.wang@intel.com, rodrigo.vivi@intel.com, intel-gvt-dev@lists.freedesktop.org, akrowiak@linux.ibm.com, oberpar@linux.ibm.com, tiwei.bie@intel.com, netdev@vger.kernel.org, cohuck@redhat.com, linux-kernel@vger.kernel.org, maxime.coquelin@redhat.com, lingshan.zhu@intel.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" Message-ID: <20191107090109.C7luKFb2AmWA12mVAXgwFfm4K5H0tCQOrESDL9mB-wg@z> T24gV2VkLCBOb3YgMDYsIDIwMTkgYXQgMDM6MDU6NDJQTSArMDgwMCwgSmFzb24gV2FuZyB3cm90 ZToKPiBIaSBhbGw6Cj4gCj4gVGhlcmUgYXJlIGhhcmR3YXJlcyB0aGF0IGNhbiBkbyB2aXJ0aW8g ZGF0YXBhdGggb2ZmbG9hZGluZyB3aGlsZQo+IGhhdmluZyBpdHMgb3duIGNvbnRyb2wgcGF0aC4g VGhpcyBwYXRoIHRyaWVzIHRvIGltcGxlbWVudCBhIG1kZXYgYmFzZWQKPiB1bmlmaWVkIEFQSSB0 byBzdXBwb3J0IHVzaW5nIGtlcm5lbCB2aXJ0aW8gZHJpdmVyIHRvIGRyaXZlIHRob3NlCj4gZGV2 aWNlcy4gVGhpcyBpcyBkb25lIGJ5IGludHJvZHVjaW5nIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZv ciB2aXJ0aW8KPiAodmlydGlvX21kZXYpIGFuZCByZWdpc3RlciBpdHNlbGYgYXMgYSBuZXcga2lu ZCBvZiBtZGV2IGRyaXZlci4gVGhlbgo+IGl0IHByb3ZpZGVzIGEgdW5pZmllZCB3YXkgZm9yIGtl cm5lbCB2aXJ0aW8gZHJpdmVyIHRvIHRhbGsgd2l0aCBtZGV2Cj4gZGV2aWNlIGltcGxlbWVudGF0 aW9uLgo+IAo+IFRob3VnaCB0aGUgc2VyaWVzIG9ubHkgY29udGFpbnMga2VybmVsIGRyaXZlciBz dXBwb3J0LCB0aGUgZ29hbCBpcyB0bwo+IG1ha2UgdGhlIHRyYW5zcG9ydCBnZW5lcmljIGVub3Vn aCB0byBzdXBwb3J0IHVzZXJzcGFjZSBkcml2ZXJzLiBUaGlzCj4gbWVhbnMgdmhvc3QtbWRldlsx XSBjb3VsZCBiZSBidWlsdCBvbiB0b3AgYXMgd2VsbCBieSByZXN1aW5nIHRoZQo+IHRyYW5zcG9y dC4KPiAKPiBBIHNhbXBsZSBkcml2ZXIgaXMgYWxzbyBpbXBsZW1lbnRlZCB3aGljaCBzaW11bGF0 ZSBhIHZpcml0by1uZXQKPiBsb29wYmFjayBldGhlcm5ldCBkZXZpY2Ugb24gdG9wIG9mIHZyaW5n aCArIHdvcmtxdWV1ZS4gVGhpcyBjb3VsZCBiZQo+IHVzZWQgYXMgYSByZWZlcmVuY2UgaW1wbGVt ZW50YXRpb24gZm9yIHJlYWwgaGFyZHdhcmUgZHJpdmVyLgo+IAo+IEFsc28gYSByZWFsIElGQyBW RiBkcml2ZXIgd2FzIGFsc28gcG9zdGVkIGhlcmVbMl0gd2hpY2ggaXMgYSBnb29kCj4gcmVmZXJl bmNlIGZvciB2ZW5kb3JzIHdobyBpcyBpbnRlcmVzdGVkIGluIHRoZWlyIG93biB2aXJ0aW8gZGF0 YXBhdGgKPiBvZmZsb2FkaW5nIHByb2R1Y3QuCj4gCj4gQ29uc2lkZXIgbWRldiBmcmFtZXdvcmsg b25seSBzdXBwb3J0IFZGSU8gZGV2aWNlIGFuZCBkcml2ZXIgcmlnaHQgbm93LAo+IHRoaXMgc2Vy aWVzIGFsc28gZXh0ZW5kIGl0IHRvIHN1cHBvcnQgb3RoZXIgdHlwZXMuIFRoaXMgaXMgZG9uZQo+ IHRocm91Z2ggaW50cm9kdWNpbmcgY2xhc3MgaWQgdG8gdGhlIGRldmljZSBhbmQgcGFpcmluZyBp dCB3aXRoCj4gaWRfdGFsYmUgY2xhaW1lZCBieSB0aGUgZHJpdmVyLiBPbiB0b3AsIHRoaXMgc2Vy aXMgYWxzbyBkZWNvdXBsZQo+IGRldmljZSBzcGVjaWZpYyBwYXJlbnRzIG9wcyBvdXQgb2YgdGhl IGNvbW1vbiBvbmVzLgo+IAo+IFBrdGdlbiB0ZXN0IHdhcyBkb25lIHdpdGggdmlyaXRvLW5ldCAr IG12bmV0IGxvb3AgYmFjayBkZXZpY2UuCj4gCj4gUGxlYXNlIHJldmlldy4KPiAKPiBbMV0gaHR0 cHM6Ly9sa21sLm9yZy9sa21sLzIwMTkvMTEvNS80MjQKPiBbMl0gaHR0cHM6Ly9sa21sLm9yZy9s a21sLzIwMTkvMTEvNS8yMjcKClNlcmllczoKCkFja2VkLWJ5OiBNaWNoYWVsIFMuIFRzaXJraW4g PG1zdEByZWRoYXQuY29tPgoKCj4gQ2hhbmdlcyBmcm9tIFY4Ogo+IC0gdHJ5IHNpbGVudCBjaGVj a3BhdGNoLCBzb21lIGFyZSBzdGlsbCB0aGVyZSBiZWN1YXNlIHRoZXkgd2VyZSBpbmhlcml0ZWQK PiAgIGZyb20gdmlydGlvX2NvbmZpZ19vcHMgd2hpY2ggbmVlZHMgdG8gYmUgcmVzb2x2ZWQgaW4g YW4gaW5kZXBlbmRlbnQgc2VyaWVzCj4gLSB0d2VhayBvbiB0aGUgY29tbWVudCBhbmQgZG9jCj4g LSByZW1vdmUgVklSVElPX01ERVZfRl9WRVJTSU9OXzEgY29tcGxldGVseQo+IC0gcmVuYW1lIENP TkZJR19WSVJUSU9fTURFVl9ERVZJQ0UgdG8gQ09ORklHX1ZJUlRJT19NREVWCj4gCj4gQ2hhbmdl cyBmcm9tIFY3Ogo+IC0gZHJvcCB7c2V0fGdldH1fbWRldl9mZWF0dXJlcyBmb3IgdmlydGlvCj4g LSB0eXBvIGFuZCBjb21tZW50IHN0eWxlIGZpeGVzCj4gCj4gQ2hhbmdlcyBmcm9tIFY2Ogo+IC0g cmVuYW1lIG9wcyBmaWxlcyBhbmQgY29tcGlsZSBndWFyZAo+IAo+IENoYW5nZXMgZnJvbSBWNToK PiAtIHVzZSBkZXZfd2FybigpIGluc3RlYWQgb2YgV0FSTigxKSB3aGVuIGNsYXNzIGlkIGlzIG5v dCBzZXQKPiAtIHZhbGlkYXRlIGlkX3RhYmxlIGJlZm9yZSB0cnlpbmcgdG8gZG8gbWF0Y2hpbmcg YmV0d2VlbiBkZXZpY2UgYW5kCj4gICBkcml2ZXIKPiAtIGFkZCB3aWxkY2FyZCBmb3IgbW9kcG9z dCBzY3JpcHQKPiAtIHVzZSB1bmlxdWUgbmFtZSBmb3IgaWRfdGFibGUKPiAtIG1vdmUgZ2V0X21k ZXZfZmVhdHVyZXMoKSB0byBiZSB0aGUgZmlyc3QgbWVtYmVyIG9mIHZpcnRpb19kZXZpY2Vfb3Bz Cj4gICBhbmQgbW9yZSBjb21tZW50cyBmb3IgaXQKPiAtIHR5cG8gZml4ZXMgZm9yIHRoZSBjb21t ZW50cyBhYm92ZSB2aXJ0aW9fbWRldl9vcHMKPiAKPiBDaGFuZ2VzIGZyb20gVjQ6Cj4gLSBrZWVw IG1kZXZfc2V0X2NsYXNzKCkgZm9yIHRoZSBkZXZpY2UgdGhhdCBkb2Vzbid0IHVzZSBkZXZpY2Ug b3BzCj4gLSB1c2UgdW5pb24gZm9yIGRldmljZSBvcHMgcG9pbnRlciBpbiBtZGV2X2RldmljZQo+ IC0gaW50cm9kdWNlIGNsYXNzIHNwZWNpZmljIGhlbHBlciBmb3IgZ2V0dGluZyBpcyBkZXZpY2Ug b3BzCj4gLSB1c2UgV0FSTl9PTiBpbnN0ZWFkIG9mIEJVR19PTiBpbiBtZGV2X3NldF92aXJ0aW9f b3BzCj4gLSBleHBsYWluIGRldGFpbHMgb2YgZ2V0X21kZXZfZmVhdHVyZXMoKSBhbmQgZ2V0X3Zl bmRvcl9pZCgpCj4gLSBkaXN0aW5ndWlzaCB0aGUgb3B0aW9uYWwgdmlyaXRvIGRldmljZSBvcHMg ZnJvbSBtYW5kYXRvcnkgb25lcyBhbmQKPiAgIG1ha2UgZ2V0X2dlbmVyYXRpb24oKSBvcHRpb25h bAo+IC0gcmVuYW1lIHZmaW9fbWRldi5oIHRvIHZmaW9fbWRldl9vcHMuaCwgcmVuYW1lIHZpcml0 b19tZGV2LmggdG8KPiAgIHZpcnRpb19tZGV2X29wcy5oCj4gLSBkb24ndCBhYnVzZSB2ZXJzaW9u IGZpbGVkcyBpbiB2aXJ0aW9fbWRldiBzdHJ1Y3R1cmUsIHVzZSBmZWF0dXJlcwo+ICAgaW5zdGVh ZAo+IC0gZml4IHdhcm5pbmcgZHVyaW5nIGRldmljZSByZW1vdmUKPiAtIHN0eWxlICYgZG9jcyB0 d2Vha3MgYW5kIHR5cG8gZml4ZXMKPiAKPiBDaGFuZ2VzIGZyb20gVjM6Cj4gLSBkb2N1bWVudCB0 aGF0IGNsYXNzIGlkIChkZXZpY2Ugb3BzKSBtdXN0IGJlIHNwZWNpZmllZCBpbiBjcmVhdGUoKQo+ IC0gYWRkIFdBUk4oKSB3aGVuIHRyeWluZyB0byBzZXQgY2xhc3NfaWQgd2hlbiBpdCBoYXMgYWxy ZWFkeSBzZXQKPiAtIGFkZCBXQVJOKCkgd2hlbiBjbGFzc19pZCBpcyBub3Qgc3BlY2lmaWVkIGlu IGNyZWF0ZSgpIGFuZCBjb3JyZWN0bHkKPiAgIHJldHVybiBhbiBlcnJvciBpbiB0aGlzIGNhc2UK PiAtIGNvcnJlY3QgdGhlIHByb3RvdHlwZSBvZiBtZGV2X3NldF9jbGFzcygpIGluIHRoZSBkb2MK PiAtIGFkZCBkb2N1bWVudGlvbiBvZiBtZGV2X3NldF9jbGFzcygpCj4gLSByZW1vdmUgdGhlIHVu bmVjZXNzYXJ5ICJjbGFzc19pZF9mYWlsIiBsYWJlbCB3aGVuIGNsYXNzIGlkIGlzIG5vdAo+ICAg c3BlY2lmaWVkIGluIGNyZWF0ZSgpCj4gLSBjb252ZXJ0IGlkX3RhYmxlIGluIHZmaW9fbWRldiB0 byBjb25zdAo+IC0gbW92ZSBtZGV2X3NldF9jbGFzcyBhbmQgaXRzIGZyaWVuZHMgYWZ0ZXIgbWRl dl91dWlkKCkKPiAtIHN1cWFzaCB0aGUgcGF0Y2ggb2YgYnVzIHVldmVudCBpbnRvIHBhdGNoIG9m IGludHJvZHVjaW5nIGNsYXNzIGlkCj4gLSB0d2VhayB0aGUgd29yZHMgaW4gdGhlIGRvY3MgcGVy IENvcm5lbGlhIHN1Z2dlc3Rpb24KPiAtIHRpZSBjbGFzc19pZCBhbmQgZGV2aWNlIG9wcyB0aHJv dWdoIGNsYXNzIHNwZWNpZmljIGluaXRpYWxpemF0aW9uCj4gICByb3V0aW5lIGxpa2UgbWRldl9z ZXRfdmZpb19vcHMoKQo+IC0gdHlwb3MgZml4ZXMgaW4gdGhlIGRvY3Mgb2YgdmlydGlvLW1kZXYg Y2FsbGJhY2tzCj4gLSBkb2N1bWVudCB0aGUgdXNhZ2Ugb2YgdmlydHF1ZXVlcyBpbiBzdHJ1Y3Qg dmlydGlvX21kZXZfZGV2aWNlCj4gLSByZW1vdmUgdGhlIHVzZWxlc3MgdnFzIGFycmF5IGluIHN0 cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UKPiAtIHJlbmFtZSBNREVWX0lEX1hYWCB0byBNREVWX0NM QVNTX0lEX1hYWAo+IAo+IENoYW5nZXMgZnJvbSBWMjoKPiAtIGZhaWwgd2hlbiBjbGFzc19pZCBp cyBub3Qgc3BlY2lmaWVkCj4gLSBkcm9wIHRoZSB2cmluZ2ggcGF0Y2gKPiAtIG1hdGNoIHRoZSBk b2MgdG8gdGhlIGNvZGUKPiAtIHR3ZWFrIHRoZSBjb21taXQgbG9nCj4gLSBtb3ZlIGRldmljZV9v cHMgZnJvbSBwYXJlbnQgdG8gbWRldiBkZXZpY2UKPiAtIHJlbW92ZSB0aGUgdW51c2VkIE1ERVZf SURfVkhPU1QKPiAKPiBDaGFuZ2VzIGZyb20gVjE6Cj4gLSBtb3ZlIHZpcnRpb19tZGV2LmMgdG8g ZHJpdmVycy92aXJ0aW8KPiAtIHN0b3JlIGNsYXNzX2lkIGluIG1kZXZfZGV2aWNlIGluc3RlYWQg b2YgbWRldl9wYXJlbnQKPiAtIHN0b3JlIGRldmljZV9vcHMgaW4gbWRldl9kZXZpY2UgaW5zdGVh ZCBvZiBtZGV2X3BhcmVudAo+IC0gcmVvcmRlciB0aGUgcGF0Y2gsIHZyaW5naCBmaXggY29tZXMg Zmlyc3QKPiAtIHJlYWxseSBzaWxlbnQgY29tcGlsaW5nIHdhcm5pbmdzCj4gLSByZWFsbHkgc3dp dGNoIHRvIHVzZSB1MTYgZm9yIGNsYXNzX2lkCj4gLSB1ZXZlbnQgYW5kIG1vZHBvc3Qgc3VwcG9y dCBmb3IgbWRldiBjbGFzc19pZAo+IC0gdnJhaW91cyB0d2Vha3MgcGVyIGNvbW1lbnRzIGZyb20g UGFyYXYKPiAKPiBDaGFuZ2VzIGZyb20gUkZDLVYyOgo+IC0gc2lsZW50IGNvbXBpbGUgd2Fybmlu Z3Mgb24gc29tZSBzcGVjaWZpYyBjb25maWd1cmF0aW9uCj4gLSB1c2UgdTE2IGluc3RlYWQgdTgg Zm9yIGNsYXNzIGlkCj4gLSByZXNldmUgTURFVl9JRF9WSE9TVCBmb3IgZnV0dXJlIHZob3N0LW1k ZXYgd29yawo+IC0gaW50cm9kdWNlICJ2aXJ0aW8iIHR5cGUgZm9yIG12bmV0IGFuZCBtYWtlICJ2 aG9zdCIgdHlwZSBmb3IgZnV0dXJlCj4gICB3b3JrCj4gLSBhZGQgZW50cmllcyBpbiBNQUlOVEFJ TkVSCj4gLSB0d2VhayBhbmQgdHlwb3MgZml4ZXMgaW4gY29tbWl0IGxvZwo+IAo+IENoYW5nZXMg ZnJvbSBSRkMtVjE6Cj4gLSByZW5hbWUgZGV2aWNlIGlkIHRvIGNsYXNzIGlkCj4gLSBhZGQgZG9j cyBmb3IgY2xhc3MgaWQgYW5kIGRldmljZSBzcGVjaWZpYyBvcHMgKGRldmljZV9vcHMpCj4gLSBz cGxpdCBkZXZpY2Vfb3BzIGludG8gc2VwZXJhdGUgaGVhZGVycwo+IC0gZHJvcCB0aGUgbWRldl9z ZXRfZG1hX29wcygpCj4gLSB1c2UgZGV2aWNlX29wcyB0byBpbXBsZW1lbnQgdGhlIHRyYW5zcG9y dCBBUEksIHRoZW4gaXQncyBub3QgYSBwYXJ0Cj4gICBvZiBVQVBJIGFueSBtb3JlCj4gLSB1c2Ug R0ZQX0FUT01JQyBpbiBtdm5ldCBzYW1wbGUgZGV2aWNlIGFuZCBvdGhlciB0d2Vha3MKPiAtIHNl dF92cmluZ19iYXNlL2dldF92cmluZ19iYXNlIHN1cHBvcnQgZm9yIG12bmV0IGRldmljZQo+IAo+ IEphc29uIFdhbmcgKDYpOgo+ICAgbWRldjogY2xhc3MgaWQgc3VwcG9ydAo+ICAgbW9kcG9zdDog YWRkIHN1cHBvcnQgZm9yIG1kZXYgY2xhc3MgaWQKPiAgIG1kZXY6IGludHJvZHVjZSBkZXZpY2Ug c3BlY2lmaWMgb3BzCj4gICBtZGV2OiBpbnRyb2R1Y2UgdmlydGlvIGRldmljZSBhbmQgaXRzIGRl dmljZSBvcHMKPiAgIHZpcnRpbzogaW50cm9kdWNlIGEgbWRldiBiYXNlZCB0cmFuc3BvcnQKPiAg IGRvY3M6IHNhbXBsZSBkcml2ZXIgdG8gZGVtb25zdHJhdGUgaG93IHRvIGltcGxlbWVudCB2aXJ0 aW8tbWRldgo+ICAgICBmcmFtZXdvcmsKPiAKPiAgLi4uL2RyaXZlci1hcGkvdmZpby1tZWRpYXRl ZC1kZXZpY2UucnN0ICAgICAgIHwgIDM4ICstCj4gIE1BSU5UQUlORVJTICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICB8ICAgMyArCj4gIGRyaXZlcnMvZ3B1L2RybS9pOTE1L2d2dC9r dm1ndC5jICAgICAgICAgICAgICB8ICAxNyArLQo+ICBkcml2ZXJzL3MzOTAvY2lvL3ZmaW9fY2N3 X29wcy5jICAgICAgICAgICAgICAgfCAgMTcgKy0KPiAgZHJpdmVycy9zMzkwL2NyeXB0by92Zmlv X2FwX29wcy5jICAgICAgICAgICAgIHwgIDEzICstCj4gIGRyaXZlcnMvdmZpby9tZGV2L21kZXZf Y29yZS5jICAgICAgICAgICAgICAgICB8ICA2MCArKwo+ICBkcml2ZXJzL3ZmaW8vbWRldi9tZGV2 X2RyaXZlci5jICAgICAgICAgICAgICAgfCAgMjUgKwo+ICBkcml2ZXJzL3ZmaW8vbWRldi9tZGV2 X3ByaXZhdGUuaCAgICAgICAgICAgICAgfCAgIDggKwo+ICBkcml2ZXJzL3ZmaW8vbWRldi92Zmlv X21kZXYuYyAgICAgICAgICAgICAgICAgfCAgNDUgKy0KPiAgZHJpdmVycy92aXJ0aW8vS2NvbmZp ZyAgICAgICAgICAgICAgICAgICAgICAgIHwgIDEzICsKPiAgZHJpdmVycy92aXJ0aW8vTWFrZWZp bGUgICAgICAgICAgICAgICAgICAgICAgIHwgICAxICsKPiAgZHJpdmVycy92aXJ0aW8vdmlydGlv X21kZXYuYyAgICAgICAgICAgICAgICAgIHwgNDA2ICsrKysrKysrKysrCj4gIGluY2x1ZGUvbGlu dXgvbWRldi5oICAgICAgICAgICAgICAgICAgICAgICAgICB8ICA1NyArLQo+ICBpbmNsdWRlL2xp bnV4L21kZXZfdmZpb19vcHMuaCAgICAgICAgICAgICAgICAgfCAgNTIgKysKPiAgaW5jbHVkZS9s aW51eC9tZGV2X3ZpcnRpb19vcHMuaCAgICAgICAgICAgICAgIHwgMTQ3ICsrKysKPiAgaW5jbHVk ZS9saW51eC9tb2RfZGV2aWNldGFibGUuaCAgICAgICAgICAgICAgIHwgICA4ICsKPiAgc2FtcGxl cy9LY29uZmlnICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwgIDEwICsKPiAgc2FtcGxl cy92ZmlvLW1kZXYvTWFrZWZpbGUgICAgICAgICAgICAgICAgICAgIHwgICAxICsKPiAgc2FtcGxl cy92ZmlvLW1kZXYvbWJvY2hzLmMgICAgICAgICAgICAgICAgICAgIHwgIDE5ICstCj4gIHNhbXBs ZXMvdmZpby1tZGV2L21kcHkuYyAgICAgICAgICAgICAgICAgICAgICB8ICAxOSArLQo+ICBzYW1w bGVzL3ZmaW8tbWRldi9tdHR5LmMgICAgICAgICAgICAgICAgICAgICAgfCAgMTcgKy0KPiAgc2Ft cGxlcy92ZmlvLW1kZXYvbXZuZXQuYyAgICAgICAgICAgICAgICAgICAgIHwgNjg2ICsrKysrKysr KysrKysrKysrKwo+ICBzY3JpcHRzL21vZC9kZXZpY2V0YWJsZS1vZmZzZXRzLmMgICAgICAgICAg ICAgfCAgIDMgKwo+ICBzY3JpcHRzL21vZC9maWxlMmFsaWFzLmMgICAgICAgICAgICAgICAgICAg ICAgfCAgMTEgKwo+ICAyNCBmaWxlcyBjaGFuZ2VkLCAxNTg1IGluc2VydGlvbnMoKyksIDkxIGRl bGV0aW9ucygtKQo+ICBjcmVhdGUgbW9kZSAxMDA2NDQgZHJpdmVycy92aXJ0aW8vdmlydGlvX21k ZXYuYwo+ICBjcmVhdGUgbW9kZSAxMDA2NDQgaW5jbHVkZS9saW51eC9tZGV2X3ZmaW9fb3BzLmgK PiAgY3JlYXRlIG1vZGUgMTAwNjQ0IGluY2x1ZGUvbGludXgvbWRldl92aXJ0aW9fb3BzLmgKPiAg Y3JlYXRlIG1vZGUgMTAwNjQ0IHNhbXBsZXMvdmZpby1tZGV2L212bmV0LmMKPiAKPiAtLSAKPiAy LjE5LjEKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KZHJp LWRldmVsIG1haWxpbmcgbGlzdApkcmktZGV2ZWxAbGlzdHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBz Oi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vZHJpLWRldmVs 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=-0.7 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=no 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 56528FA372C for ; Thu, 7 Nov 2019 09:01:26 +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 30619218AE for ; Thu, 7 Nov 2019 09:01:26 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 30619218AE 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 99F7E6F392; Thu, 7 Nov 2019 09:01:25 +0000 (UTC) Received: from mx1.redhat.com (mx1.redhat.com [209.132.183.28]) by gabe.freedesktop.org (Postfix) with ESMTPS id 062FE6F394 for ; Thu, 7 Nov 2019 09:01:24 +0000 (UTC) Received: from mail-qt1-f200.google.com (mail-qt1-f200.google.com [209.85.160.200]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 6809C7C0A7 for ; Thu, 7 Nov 2019 09:01:23 +0000 (UTC) Received: by mail-qt1-f200.google.com with SMTP id b26so1720375qtr.23 for ; Thu, 07 Nov 2019 01:01:23 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=Iuf7pY0vuoI1H2ku5bfjNilR7JIa9xxrVrj3ZMN2r0I=; b=aDdUCQ/LGQ0D2f4LvFg9UKn06rEh2JN3PlQYLfHVyY0mHXUss5VQXe2YzyN1LCoOqi 7GDD4RGwi/El2DmHYFqA35vmr0IQsmcCc3xOF47GD6lsT/G9SHUjxLXyDg3rA8ghg5CR GtLoXaRo92iWV6Da2UnQav215A8MrPHE+vy9dvZA/r8FiqFHbENSV3VdVCyFqtcOqSBI lh3wT/tld+QUCEk+sjfQPl2IqILzXAY934loNvj0gdH3bPbpEH0N2JlDXNyICGx/jWQl PCcV/1QbSUYpC7B8ZO6Q82ThoM2UeBBXI4RyiR+WydxAr1DY8DPSaBHHvqN4ruHG4jVP kPew== X-Gm-Message-State: APjAAAU6KqeB9DVyVIuZioBPlnmGf8PTSfgKK4j/6TJrfTzbmwX+ITJ8 WJDofwu7WecL6FYOajihdAlcm9F0fwSIbkkvEcFW+K9mF5dh4jAQjl6JPourl58ToO8RaFTNwnz /OErAvWg3zhMZcFw/pBtEfoT6giHv X-Received: by 2002:a37:9d0:: with SMTP id 199mr1741264qkj.356.1573117282584; Thu, 07 Nov 2019 01:01:22 -0800 (PST) X-Google-Smtp-Source: APXvYqza6VsCEEQioEycCTS7IjmrN8FqLVHpcn7603qJAchUJjGf6blUNptyX48oixjHG7mtpq7G3A== X-Received: by 2002:a37:9d0:: with SMTP id 199mr1741203qkj.356.1573117282207; Thu, 07 Nov 2019 01:01:22 -0800 (PST) Received: from redhat.com (bzq-79-178-12-128.red.bezeqint.net. [79.178.12.128]) by smtp.gmail.com with ESMTPSA id o1sm958206qtb.82.2019.11.07.01.01.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Nov 2019 01:01:21 -0800 (PST) Date: Thu, 7 Nov 2019 04:01:09 -0500 From: "Michael S. Tsirkin" To: Jason Wang Message-ID: <20191107040055-mutt-send-email-mst@kernel.org> References: <20191106070548.18980-1-jasowang@redhat.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20191106070548.18980-1-jasowang@redhat.com> Subject: Re: [Intel-gfx] [PATCH V9 0/6] mdev based hardware virtio offloading support 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: stefanha@redhat.com, christophe.de.dinechin@gmail.com, kvm@vger.kernel.org, airlied@linux.ie, heiko.carstens@de.ibm.com, dri-devel@lists.freedesktop.org, virtualization@lists.linux-foundation.org, kwankhede@nvidia.com, rob.miller@broadcom.com, linux-s390@vger.kernel.org, sebott@linux.ibm.com, lulu@redhat.com, eperezma@redhat.com, pasic@linux.ibm.com, borntraeger@de.ibm.com, haotian.wang@sifive.com, cunming.liang@intel.com, farman@linux.ibm.com, idos@mellanox.com, gor@linux.ibm.com, intel-gfx@lists.freedesktop.org, xiao.w.wang@intel.com, freude@linux.ibm.com, parav@mellanox.com, zhihong.wang@intel.com, intel-gvt-dev@lists.freedesktop.org, akrowiak@linux.ibm.com, oberpar@linux.ibm.com, tiwei.bie@intel.com, netdev@vger.kernel.org, cohuck@redhat.com, linux-kernel@vger.kernel.org, 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: <20191107090109.l2YuZIpVzGzKJL75huky8U5waNsnNghkc3PGB9xGnUo@z> T24gV2VkLCBOb3YgMDYsIDIwMTkgYXQgMDM6MDU6NDJQTSArMDgwMCwgSmFzb24gV2FuZyB3cm90 ZToKPiBIaSBhbGw6Cj4gCj4gVGhlcmUgYXJlIGhhcmR3YXJlcyB0aGF0IGNhbiBkbyB2aXJ0aW8g ZGF0YXBhdGggb2ZmbG9hZGluZyB3aGlsZQo+IGhhdmluZyBpdHMgb3duIGNvbnRyb2wgcGF0aC4g VGhpcyBwYXRoIHRyaWVzIHRvIGltcGxlbWVudCBhIG1kZXYgYmFzZWQKPiB1bmlmaWVkIEFQSSB0 byBzdXBwb3J0IHVzaW5nIGtlcm5lbCB2aXJ0aW8gZHJpdmVyIHRvIGRyaXZlIHRob3NlCj4gZGV2 aWNlcy4gVGhpcyBpcyBkb25lIGJ5IGludHJvZHVjaW5nIGEgbmV3IG1kZXYgdHJhbnNwb3J0IGZv ciB2aXJ0aW8KPiAodmlydGlvX21kZXYpIGFuZCByZWdpc3RlciBpdHNlbGYgYXMgYSBuZXcga2lu ZCBvZiBtZGV2IGRyaXZlci4gVGhlbgo+IGl0IHByb3ZpZGVzIGEgdW5pZmllZCB3YXkgZm9yIGtl cm5lbCB2aXJ0aW8gZHJpdmVyIHRvIHRhbGsgd2l0aCBtZGV2Cj4gZGV2aWNlIGltcGxlbWVudGF0 aW9uLgo+IAo+IFRob3VnaCB0aGUgc2VyaWVzIG9ubHkgY29udGFpbnMga2VybmVsIGRyaXZlciBz dXBwb3J0LCB0aGUgZ29hbCBpcyB0bwo+IG1ha2UgdGhlIHRyYW5zcG9ydCBnZW5lcmljIGVub3Vn aCB0byBzdXBwb3J0IHVzZXJzcGFjZSBkcml2ZXJzLiBUaGlzCj4gbWVhbnMgdmhvc3QtbWRldlsx XSBjb3VsZCBiZSBidWlsdCBvbiB0b3AgYXMgd2VsbCBieSByZXN1aW5nIHRoZQo+IHRyYW5zcG9y dC4KPiAKPiBBIHNhbXBsZSBkcml2ZXIgaXMgYWxzbyBpbXBsZW1lbnRlZCB3aGljaCBzaW11bGF0 ZSBhIHZpcml0by1uZXQKPiBsb29wYmFjayBldGhlcm5ldCBkZXZpY2Ugb24gdG9wIG9mIHZyaW5n aCArIHdvcmtxdWV1ZS4gVGhpcyBjb3VsZCBiZQo+IHVzZWQgYXMgYSByZWZlcmVuY2UgaW1wbGVt ZW50YXRpb24gZm9yIHJlYWwgaGFyZHdhcmUgZHJpdmVyLgo+IAo+IEFsc28gYSByZWFsIElGQyBW RiBkcml2ZXIgd2FzIGFsc28gcG9zdGVkIGhlcmVbMl0gd2hpY2ggaXMgYSBnb29kCj4gcmVmZXJl bmNlIGZvciB2ZW5kb3JzIHdobyBpcyBpbnRlcmVzdGVkIGluIHRoZWlyIG93biB2aXJ0aW8gZGF0 YXBhdGgKPiBvZmZsb2FkaW5nIHByb2R1Y3QuCj4gCj4gQ29uc2lkZXIgbWRldiBmcmFtZXdvcmsg b25seSBzdXBwb3J0IFZGSU8gZGV2aWNlIGFuZCBkcml2ZXIgcmlnaHQgbm93LAo+IHRoaXMgc2Vy aWVzIGFsc28gZXh0ZW5kIGl0IHRvIHN1cHBvcnQgb3RoZXIgdHlwZXMuIFRoaXMgaXMgZG9uZQo+ IHRocm91Z2ggaW50cm9kdWNpbmcgY2xhc3MgaWQgdG8gdGhlIGRldmljZSBhbmQgcGFpcmluZyBp dCB3aXRoCj4gaWRfdGFsYmUgY2xhaW1lZCBieSB0aGUgZHJpdmVyLiBPbiB0b3AsIHRoaXMgc2Vy aXMgYWxzbyBkZWNvdXBsZQo+IGRldmljZSBzcGVjaWZpYyBwYXJlbnRzIG9wcyBvdXQgb2YgdGhl IGNvbW1vbiBvbmVzLgo+IAo+IFBrdGdlbiB0ZXN0IHdhcyBkb25lIHdpdGggdmlyaXRvLW5ldCAr IG12bmV0IGxvb3AgYmFjayBkZXZpY2UuCj4gCj4gUGxlYXNlIHJldmlldy4KPiAKPiBbMV0gaHR0 cHM6Ly9sa21sLm9yZy9sa21sLzIwMTkvMTEvNS80MjQKPiBbMl0gaHR0cHM6Ly9sa21sLm9yZy9s a21sLzIwMTkvMTEvNS8yMjcKClNlcmllczoKCkFja2VkLWJ5OiBNaWNoYWVsIFMuIFRzaXJraW4g PG1zdEByZWRoYXQuY29tPgoKCj4gQ2hhbmdlcyBmcm9tIFY4Ogo+IC0gdHJ5IHNpbGVudCBjaGVj a3BhdGNoLCBzb21lIGFyZSBzdGlsbCB0aGVyZSBiZWN1YXNlIHRoZXkgd2VyZSBpbmhlcml0ZWQK PiAgIGZyb20gdmlydGlvX2NvbmZpZ19vcHMgd2hpY2ggbmVlZHMgdG8gYmUgcmVzb2x2ZWQgaW4g YW4gaW5kZXBlbmRlbnQgc2VyaWVzCj4gLSB0d2VhayBvbiB0aGUgY29tbWVudCBhbmQgZG9jCj4g LSByZW1vdmUgVklSVElPX01ERVZfRl9WRVJTSU9OXzEgY29tcGxldGVseQo+IC0gcmVuYW1lIENP TkZJR19WSVJUSU9fTURFVl9ERVZJQ0UgdG8gQ09ORklHX1ZJUlRJT19NREVWCj4gCj4gQ2hhbmdl cyBmcm9tIFY3Ogo+IC0gZHJvcCB7c2V0fGdldH1fbWRldl9mZWF0dXJlcyBmb3IgdmlydGlvCj4g LSB0eXBvIGFuZCBjb21tZW50IHN0eWxlIGZpeGVzCj4gCj4gQ2hhbmdlcyBmcm9tIFY2Ogo+IC0g cmVuYW1lIG9wcyBmaWxlcyBhbmQgY29tcGlsZSBndWFyZAo+IAo+IENoYW5nZXMgZnJvbSBWNToK PiAtIHVzZSBkZXZfd2FybigpIGluc3RlYWQgb2YgV0FSTigxKSB3aGVuIGNsYXNzIGlkIGlzIG5v dCBzZXQKPiAtIHZhbGlkYXRlIGlkX3RhYmxlIGJlZm9yZSB0cnlpbmcgdG8gZG8gbWF0Y2hpbmcg YmV0d2VlbiBkZXZpY2UgYW5kCj4gICBkcml2ZXIKPiAtIGFkZCB3aWxkY2FyZCBmb3IgbW9kcG9z dCBzY3JpcHQKPiAtIHVzZSB1bmlxdWUgbmFtZSBmb3IgaWRfdGFibGUKPiAtIG1vdmUgZ2V0X21k ZXZfZmVhdHVyZXMoKSB0byBiZSB0aGUgZmlyc3QgbWVtYmVyIG9mIHZpcnRpb19kZXZpY2Vfb3Bz Cj4gICBhbmQgbW9yZSBjb21tZW50cyBmb3IgaXQKPiAtIHR5cG8gZml4ZXMgZm9yIHRoZSBjb21t ZW50cyBhYm92ZSB2aXJ0aW9fbWRldl9vcHMKPiAKPiBDaGFuZ2VzIGZyb20gVjQ6Cj4gLSBrZWVw IG1kZXZfc2V0X2NsYXNzKCkgZm9yIHRoZSBkZXZpY2UgdGhhdCBkb2Vzbid0IHVzZSBkZXZpY2Ug b3BzCj4gLSB1c2UgdW5pb24gZm9yIGRldmljZSBvcHMgcG9pbnRlciBpbiBtZGV2X2RldmljZQo+ IC0gaW50cm9kdWNlIGNsYXNzIHNwZWNpZmljIGhlbHBlciBmb3IgZ2V0dGluZyBpcyBkZXZpY2Ug b3BzCj4gLSB1c2UgV0FSTl9PTiBpbnN0ZWFkIG9mIEJVR19PTiBpbiBtZGV2X3NldF92aXJ0aW9f b3BzCj4gLSBleHBsYWluIGRldGFpbHMgb2YgZ2V0X21kZXZfZmVhdHVyZXMoKSBhbmQgZ2V0X3Zl bmRvcl9pZCgpCj4gLSBkaXN0aW5ndWlzaCB0aGUgb3B0aW9uYWwgdmlyaXRvIGRldmljZSBvcHMg ZnJvbSBtYW5kYXRvcnkgb25lcyBhbmQKPiAgIG1ha2UgZ2V0X2dlbmVyYXRpb24oKSBvcHRpb25h bAo+IC0gcmVuYW1lIHZmaW9fbWRldi5oIHRvIHZmaW9fbWRldl9vcHMuaCwgcmVuYW1lIHZpcml0 b19tZGV2LmggdG8KPiAgIHZpcnRpb19tZGV2X29wcy5oCj4gLSBkb24ndCBhYnVzZSB2ZXJzaW9u IGZpbGVkcyBpbiB2aXJ0aW9fbWRldiBzdHJ1Y3R1cmUsIHVzZSBmZWF0dXJlcwo+ICAgaW5zdGVh ZAo+IC0gZml4IHdhcm5pbmcgZHVyaW5nIGRldmljZSByZW1vdmUKPiAtIHN0eWxlICYgZG9jcyB0 d2Vha3MgYW5kIHR5cG8gZml4ZXMKPiAKPiBDaGFuZ2VzIGZyb20gVjM6Cj4gLSBkb2N1bWVudCB0 aGF0IGNsYXNzIGlkIChkZXZpY2Ugb3BzKSBtdXN0IGJlIHNwZWNpZmllZCBpbiBjcmVhdGUoKQo+ IC0gYWRkIFdBUk4oKSB3aGVuIHRyeWluZyB0byBzZXQgY2xhc3NfaWQgd2hlbiBpdCBoYXMgYWxy ZWFkeSBzZXQKPiAtIGFkZCBXQVJOKCkgd2hlbiBjbGFzc19pZCBpcyBub3Qgc3BlY2lmaWVkIGlu IGNyZWF0ZSgpIGFuZCBjb3JyZWN0bHkKPiAgIHJldHVybiBhbiBlcnJvciBpbiB0aGlzIGNhc2UK PiAtIGNvcnJlY3QgdGhlIHByb3RvdHlwZSBvZiBtZGV2X3NldF9jbGFzcygpIGluIHRoZSBkb2MK PiAtIGFkZCBkb2N1bWVudGlvbiBvZiBtZGV2X3NldF9jbGFzcygpCj4gLSByZW1vdmUgdGhlIHVu bmVjZXNzYXJ5ICJjbGFzc19pZF9mYWlsIiBsYWJlbCB3aGVuIGNsYXNzIGlkIGlzIG5vdAo+ICAg c3BlY2lmaWVkIGluIGNyZWF0ZSgpCj4gLSBjb252ZXJ0IGlkX3RhYmxlIGluIHZmaW9fbWRldiB0 byBjb25zdAo+IC0gbW92ZSBtZGV2X3NldF9jbGFzcyBhbmQgaXRzIGZyaWVuZHMgYWZ0ZXIgbWRl dl91dWlkKCkKPiAtIHN1cWFzaCB0aGUgcGF0Y2ggb2YgYnVzIHVldmVudCBpbnRvIHBhdGNoIG9m IGludHJvZHVjaW5nIGNsYXNzIGlkCj4gLSB0d2VhayB0aGUgd29yZHMgaW4gdGhlIGRvY3MgcGVy IENvcm5lbGlhIHN1Z2dlc3Rpb24KPiAtIHRpZSBjbGFzc19pZCBhbmQgZGV2aWNlIG9wcyB0aHJv dWdoIGNsYXNzIHNwZWNpZmljIGluaXRpYWxpemF0aW9uCj4gICByb3V0aW5lIGxpa2UgbWRldl9z ZXRfdmZpb19vcHMoKQo+IC0gdHlwb3MgZml4ZXMgaW4gdGhlIGRvY3Mgb2YgdmlydGlvLW1kZXYg Y2FsbGJhY2tzCj4gLSBkb2N1bWVudCB0aGUgdXNhZ2Ugb2YgdmlydHF1ZXVlcyBpbiBzdHJ1Y3Qg dmlydGlvX21kZXZfZGV2aWNlCj4gLSByZW1vdmUgdGhlIHVzZWxlc3MgdnFzIGFycmF5IGluIHN0 cnVjdCB2aXJ0aW9fbWRldl9kZXZpY2UKPiAtIHJlbmFtZSBNREVWX0lEX1hYWCB0byBNREVWX0NM QVNTX0lEX1hYWAo+IAo+IENoYW5nZXMgZnJvbSBWMjoKPiAtIGZhaWwgd2hlbiBjbGFzc19pZCBp cyBub3Qgc3BlY2lmaWVkCj4gLSBkcm9wIHRoZSB2cmluZ2ggcGF0Y2gKPiAtIG1hdGNoIHRoZSBk b2MgdG8gdGhlIGNvZGUKPiAtIHR3ZWFrIHRoZSBjb21taXQgbG9nCj4gLSBtb3ZlIGRldmljZV9v cHMgZnJvbSBwYXJlbnQgdG8gbWRldiBkZXZpY2UKPiAtIHJlbW92ZSB0aGUgdW51c2VkIE1ERVZf SURfVkhPU1QKPiAKPiBDaGFuZ2VzIGZyb20gVjE6Cj4gLSBtb3ZlIHZpcnRpb19tZGV2LmMgdG8g ZHJpdmVycy92aXJ0aW8KPiAtIHN0b3JlIGNsYXNzX2lkIGluIG1kZXZfZGV2aWNlIGluc3RlYWQg b2YgbWRldl9wYXJlbnQKPiAtIHN0b3JlIGRldmljZV9vcHMgaW4gbWRldl9kZXZpY2UgaW5zdGVh ZCBvZiBtZGV2X3BhcmVudAo+IC0gcmVvcmRlciB0aGUgcGF0Y2gsIHZyaW5naCBmaXggY29tZXMg Zmlyc3QKPiAtIHJlYWxseSBzaWxlbnQgY29tcGlsaW5nIHdhcm5pbmdzCj4gLSByZWFsbHkgc3dp dGNoIHRvIHVzZSB1MTYgZm9yIGNsYXNzX2lkCj4gLSB1ZXZlbnQgYW5kIG1vZHBvc3Qgc3VwcG9y dCBmb3IgbWRldiBjbGFzc19pZAo+IC0gdnJhaW91cyB0d2Vha3MgcGVyIGNvbW1lbnRzIGZyb20g UGFyYXYKPiAKPiBDaGFuZ2VzIGZyb20gUkZDLVYyOgo+IC0gc2lsZW50IGNvbXBpbGUgd2Fybmlu Z3Mgb24gc29tZSBzcGVjaWZpYyBjb25maWd1cmF0aW9uCj4gLSB1c2UgdTE2IGluc3RlYWQgdTgg Zm9yIGNsYXNzIGlkCj4gLSByZXNldmUgTURFVl9JRF9WSE9TVCBmb3IgZnV0dXJlIHZob3N0LW1k ZXYgd29yawo+IC0gaW50cm9kdWNlICJ2aXJ0aW8iIHR5cGUgZm9yIG12bmV0IGFuZCBtYWtlICJ2 aG9zdCIgdHlwZSBmb3IgZnV0dXJlCj4gICB3b3JrCj4gLSBhZGQgZW50cmllcyBpbiBNQUlOVEFJ TkVSCj4gLSB0d2VhayBhbmQgdHlwb3MgZml4ZXMgaW4gY29tbWl0IGxvZwo+IAo+IENoYW5nZXMg ZnJvbSBSRkMtVjE6Cj4gLSByZW5hbWUgZGV2aWNlIGlkIHRvIGNsYXNzIGlkCj4gLSBhZGQgZG9j cyBmb3IgY2xhc3MgaWQgYW5kIGRldmljZSBzcGVjaWZpYyBvcHMgKGRldmljZV9vcHMpCj4gLSBz cGxpdCBkZXZpY2Vfb3BzIGludG8gc2VwZXJhdGUgaGVhZGVycwo+IC0gZHJvcCB0aGUgbWRldl9z ZXRfZG1hX29wcygpCj4gLSB1c2UgZGV2aWNlX29wcyB0byBpbXBsZW1lbnQgdGhlIHRyYW5zcG9y dCBBUEksIHRoZW4gaXQncyBub3QgYSBwYXJ0Cj4gICBvZiBVQVBJIGFueSBtb3JlCj4gLSB1c2Ug R0ZQX0FUT01JQyBpbiBtdm5ldCBzYW1wbGUgZGV2aWNlIGFuZCBvdGhlciB0d2Vha3MKPiAtIHNl dF92cmluZ19iYXNlL2dldF92cmluZ19iYXNlIHN1cHBvcnQgZm9yIG12bmV0IGRldmljZQo+IAo+ IEphc29uIFdhbmcgKDYpOgo+ICAgbWRldjogY2xhc3MgaWQgc3VwcG9ydAo+ICAgbW9kcG9zdDog YWRkIHN1cHBvcnQgZm9yIG1kZXYgY2xhc3MgaWQKPiAgIG1kZXY6IGludHJvZHVjZSBkZXZpY2Ug c3BlY2lmaWMgb3BzCj4gICBtZGV2OiBpbnRyb2R1Y2UgdmlydGlvIGRldmljZSBhbmQgaXRzIGRl dmljZSBvcHMKPiAgIHZpcnRpbzogaW50cm9kdWNlIGEgbWRldiBiYXNlZCB0cmFuc3BvcnQKPiAg IGRvY3M6IHNhbXBsZSBkcml2ZXIgdG8gZGVtb25zdHJhdGUgaG93IHRvIGltcGxlbWVudCB2aXJ0 aW8tbWRldgo+ICAgICBmcmFtZXdvcmsKPiAKPiAgLi4uL2RyaXZlci1hcGkvdmZpby1tZWRpYXRl ZC1kZXZpY2UucnN0ICAgICAgIHwgIDM4ICstCj4gIE1BSU5UQUlORVJTICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICB8ICAgMyArCj4gIGRyaXZlcnMvZ3B1L2RybS9pOTE1L2d2dC9r dm1ndC5jICAgICAgICAgICAgICB8ICAxNyArLQo+ICBkcml2ZXJzL3MzOTAvY2lvL3ZmaW9fY2N3 X29wcy5jICAgICAgICAgICAgICAgfCAgMTcgKy0KPiAgZHJpdmVycy9zMzkwL2NyeXB0by92Zmlv X2FwX29wcy5jICAgICAgICAgICAgIHwgIDEzICstCj4gIGRyaXZlcnMvdmZpby9tZGV2L21kZXZf Y29yZS5jICAgICAgICAgICAgICAgICB8ICA2MCArKwo+ICBkcml2ZXJzL3ZmaW8vbWRldi9tZGV2 X2RyaXZlci5jICAgICAgICAgICAgICAgfCAgMjUgKwo+ICBkcml2ZXJzL3ZmaW8vbWRldi9tZGV2 X3ByaXZhdGUuaCAgICAgICAgICAgICAgfCAgIDggKwo+ICBkcml2ZXJzL3ZmaW8vbWRldi92Zmlv X21kZXYuYyAgICAgICAgICAgICAgICAgfCAgNDUgKy0KPiAgZHJpdmVycy92aXJ0aW8vS2NvbmZp ZyAgICAgICAgICAgICAgICAgICAgICAgIHwgIDEzICsKPiAgZHJpdmVycy92aXJ0aW8vTWFrZWZp bGUgICAgICAgICAgICAgICAgICAgICAgIHwgICAxICsKPiAgZHJpdmVycy92aXJ0aW8vdmlydGlv X21kZXYuYyAgICAgICAgICAgICAgICAgIHwgNDA2ICsrKysrKysrKysrCj4gIGluY2x1ZGUvbGlu dXgvbWRldi5oICAgICAgICAgICAgICAgICAgICAgICAgICB8ICA1NyArLQo+ICBpbmNsdWRlL2xp bnV4L21kZXZfdmZpb19vcHMuaCAgICAgICAgICAgICAgICAgfCAgNTIgKysKPiAgaW5jbHVkZS9s aW51eC9tZGV2X3ZpcnRpb19vcHMuaCAgICAgICAgICAgICAgIHwgMTQ3ICsrKysKPiAgaW5jbHVk ZS9saW51eC9tb2RfZGV2aWNldGFibGUuaCAgICAgICAgICAgICAgIHwgICA4ICsKPiAgc2FtcGxl cy9LY29uZmlnICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwgIDEwICsKPiAgc2FtcGxl cy92ZmlvLW1kZXYvTWFrZWZpbGUgICAgICAgICAgICAgICAgICAgIHwgICAxICsKPiAgc2FtcGxl cy92ZmlvLW1kZXYvbWJvY2hzLmMgICAgICAgICAgICAgICAgICAgIHwgIDE5ICstCj4gIHNhbXBs ZXMvdmZpby1tZGV2L21kcHkuYyAgICAgICAgICAgICAgICAgICAgICB8ICAxOSArLQo+ICBzYW1w bGVzL3ZmaW8tbWRldi9tdHR5LmMgICAgICAgICAgICAgICAgICAgICAgfCAgMTcgKy0KPiAgc2Ft cGxlcy92ZmlvLW1kZXYvbXZuZXQuYyAgICAgICAgICAgICAgICAgICAgIHwgNjg2ICsrKysrKysr KysrKysrKysrKwo+ICBzY3JpcHRzL21vZC9kZXZpY2V0YWJsZS1vZmZzZXRzLmMgICAgICAgICAg ICAgfCAgIDMgKwo+ICBzY3JpcHRzL21vZC9maWxlMmFsaWFzLmMgICAgICAgICAgICAgICAgICAg ICAgfCAgMTEgKwo+ICAyNCBmaWxlcyBjaGFuZ2VkLCAxNTg1IGluc2VydGlvbnMoKyksIDkxIGRl bGV0aW9ucygtKQo+ICBjcmVhdGUgbW9kZSAxMDA2NDQgZHJpdmVycy92aXJ0aW8vdmlydGlvX21k ZXYuYwo+ICBjcmVhdGUgbW9kZSAxMDA2NDQgaW5jbHVkZS9saW51eC9tZGV2X3ZmaW9fb3BzLmgK PiAgY3JlYXRlIG1vZGUgMTAwNjQ0IGluY2x1ZGUvbGludXgvbWRldl92aXJ0aW9fb3BzLmgKPiAg Y3JlYXRlIG1vZGUgMTAwNjQ0IHNhbXBsZXMvdmZpby1tZGV2L212bmV0LmMKPiAKPiAtLSAKPiAy LjE5LjEKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KSW50 ZWwtZ2Z4IG1haWxpbmcgbGlzdApJbnRlbC1nZnhAbGlzdHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBz Oi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vaW50ZWwtZ2Z4