From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:54101) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1cnZp3-0000Of-2g for qemu-devel@nongnu.org; Mon, 13 Mar 2017 19:56:18 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1cnZoz-0004nm-KP for qemu-devel@nongnu.org; Mon, 13 Mar 2017 19:56:17 -0400 Received: from mail.kernel.org ([198.145.29.136]:46794) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1cnZoz-0004mm-BE for qemu-devel@nongnu.org; Mon, 13 Mar 2017 19:56:13 -0400 From: Stefano Stabellini Date: Mon, 13 Mar 2017 16:55:56 -0700 Message-Id: <1489449360-14411-5-git-send-email-sstabellini@kernel.org> In-Reply-To: <1489449360-14411-1-git-send-email-sstabellini@kernel.org> References: <1489449360-14411-1-git-send-email-sstabellini@kernel.org> Subject: [Qemu-devel] [PATCH v2 5/9] xen/9pfs: connect to the frontend List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: xen-devel@lists.xenproject.org, sstabellini@kernel.org, anthony.perard@citrix.com, groug@kaod.org, Stefano Stabellini , jgross@suse.com, "Aneesh Kumar K.V" Write the limits of the backend to xenstore. Connect to the frontend. Upon connection, allocate the rings according to the protocol specification. Initialize a QEMUBH to schedule work upon receiving an event channel notification from the frontend. Signed-off-by: Stefano Stabellini CC: anthony.perard@citrix.com CC: jgross@suse.com CC: Aneesh Kumar K.V CC: Greg Kurz --- hw/9pfs/xen-9p-backend.c | 159 ++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 158 insertions(+), 1 deletion(-) diff --git a/hw/9pfs/xen-9p-backend.c b/hw/9pfs/xen-9p-backend.c index 35032d3..0e4a133 100644 --- a/hw/9pfs/xen-9p-backend.c +++ b/hw/9pfs/xen-9p-backend.c @@ -17,8 +17,35 @@ #include "qemu/config-file.h" #include "fsdev/qemu-fsdev.h" +#define VERSIONS "1" +#define MAX_RINGS 8 +#define MAX_RING_ORDER 8 + +struct Xen9pfsRing { + struct Xen9pfsDev *priv; + + int ref; + xenevtchn_handle *evtchndev; + int evtchn; + int local_port; + struct xen_9pfs_data_intf *intf; + unsigned char *data; + struct xen_9pfs_data ring; + + QEMUBH *bh; + + /* local copies, so that we can read/write PDU data directly from + * the ring */ + RING_IDX out_cons, out_size, in_cons; + bool inprogress; +}; + typedef struct Xen9pfsDev { struct XenDevice xendev; /* must be first */ + V9fsState state; + + int num_rings; + struct Xen9pfsRing *rings; } Xen9pfsDev; static ssize_t xen_9pfs_pdu_vmarshal(V9fsPDU *pdu, @@ -67,22 +94,152 @@ static int xen_9pfs_init(struct XenDevice *xendev) return 0; } +static void xen_9pfs_bh(void *opaque) +{ +} + +static void xen_9pfs_evtchn_event(void *opaque) +{ +} + static int xen_9pfs_free(struct XenDevice *xendev) { - return -1; + int i; + struct Xen9pfsDev *xen_9pdev = container_of(xendev, struct Xen9pfsDev, xendev); + + for (i = 0; i < xen_9pdev->num_rings; i++) { + if (xen_9pdev->rings[i].data != NULL) { + xengnttab_unmap(xen_9pdev->xendev.gnttabdev, + xen_9pdev->rings[i].data, + (1 << XEN_9PFS_RING_ORDER)); + } + if (xen_9pdev->rings[i].intf != NULL) { + xengnttab_unmap(xen_9pdev->xendev.gnttabdev, + xen_9pdev->rings[i].intf, + 1); + } + if (xen_9pdev->rings[i].evtchndev > 0) { + qemu_set_fd_handler(xenevtchn_fd(xen_9pdev->rings[i].evtchndev), + NULL, NULL, NULL); + xenevtchn_unbind(xen_9pdev->rings[i].evtchndev, xen_9pdev->rings[i].local_port); + } + if (xen_9pdev->rings[i].bh != NULL) { + qemu_bh_delete(xen_9pdev->rings[i].bh); + } + } + g_free(xen_9pdev->rings); + return 0; } static int xen_9pfs_connect(struct XenDevice *xendev) { + int i; + struct Xen9pfsDev *xen_9pdev = container_of(xendev, struct Xen9pfsDev, xendev); + V9fsState *s = &xen_9pdev->state; + QemuOpts *fsdev; + char *security_model, *path; + + if (xenstore_read_fe_int(&xen_9pdev->xendev, "num-rings", + &xen_9pdev->num_rings) == -1 || + xen_9pdev->num_rings > MAX_RINGS) { + return -1; + } + + xen_9pdev->rings = g_malloc0(xen_9pdev->num_rings * sizeof(struct Xen9pfsRing)); + for (i = 0; i < xen_9pdev->num_rings; i++) { + char str[16]; + + xen_9pdev->rings[i].priv = xen_9pdev; + xen_9pdev->rings[i].evtchn = -1; + xen_9pdev->rings[i].local_port = -1; + + sprintf(str, "ring-ref%u", i); + if (xenstore_read_fe_int(&xen_9pdev->xendev, str, + &xen_9pdev->rings[i].ref) == -1) { + goto out; + } + sprintf(str, "event-channel-%u", i); + if (xenstore_read_fe_int(&xen_9pdev->xendev, str, + &xen_9pdev->rings[i].evtchn) == -1) { + goto out; + } + + xen_9pdev->rings[i].intf = xengnttab_map_grant_ref( + xen_9pdev->xendev.gnttabdev, + xen_9pdev->xendev.dom, + xen_9pdev->rings[i].ref, + PROT_READ | PROT_WRITE); + if (!xen_9pdev->rings[i].intf) { + goto out; + } + xen_9pdev->rings[i].data = xengnttab_map_domain_grant_refs( + xen_9pdev->xendev.gnttabdev, + (1 << XEN_9PFS_RING_ORDER), + xen_9pdev->xendev.dom, + xen_9pdev->rings[i].intf->ref, + PROT_READ | PROT_WRITE); + if (!xen_9pdev->rings[i].data) { + goto out; + } + xen_9pdev->rings[i].ring.in = xen_9pdev->rings[i].data; + xen_9pdev->rings[i].ring.out = xen_9pdev->rings[i].data + XEN_9PFS_RING_SIZE; + + xen_9pdev->rings[i].bh = qemu_bh_new(xen_9pfs_bh, &xen_9pdev->rings[i]); + xen_9pdev->rings[i].out_cons = 0; + xen_9pdev->rings[i].out_size = 0; + xen_9pdev->rings[i].inprogress = false; + + + xen_9pdev->rings[i].evtchndev = xenevtchn_open(NULL, 0); + if (xen_9pdev->rings[i].evtchndev == NULL) { + goto out; + } + fcntl(xenevtchn_fd(xen_9pdev->rings[i].evtchndev), F_SETFD, FD_CLOEXEC); + xen_9pdev->rings[i].local_port = xenevtchn_bind_interdomain + (xen_9pdev->rings[i].evtchndev, xendev->dom, xen_9pdev->rings[i].evtchn); + if (xen_9pdev->rings[i].local_port == -1) { + xen_pv_printf(xendev, 0, "xenevtchn_bind_interdomain failed port=%d\n", + xen_9pdev->rings[i].evtchn); + goto out; + } + xen_pv_printf(xendev, 2, "bind evtchn port %d\n", xendev->local_port); + qemu_set_fd_handler(xenevtchn_fd(xen_9pdev->rings[i].evtchndev), + xen_9pfs_evtchn_event, NULL, &xen_9pdev->rings[i]); + } + + security_model = xenstore_read_be_str(xendev, "security_model"); + path = xenstore_read_be_str(xendev, "path"); + s->fsconf.fsdev_id = g_malloc(strlen("xen9p") + 6); + sprintf(s->fsconf.fsdev_id, "xen9p%d", xendev->dev); + s->fsconf.tag = xenstore_read_fe_str(xendev, "tag"); + v9fs_register_transport(s, &xen_9p_transport); + fsdev = qemu_opts_create(qemu_find_opts("fsdev"), + s->fsconf.tag, + 1, NULL); + qemu_opt_set(fsdev, "fsdriver", "local", NULL); + qemu_opt_set(fsdev, "path", path, NULL); + qemu_opt_set(fsdev, "security_model", security_model, NULL); + qemu_opts_set_id(fsdev, s->fsconf.fsdev_id); + qemu_fsdev_add(fsdev); + v9fs_device_realize_common(s, NULL); + return 0; + +out: + xen_9pfs_free(xendev); + return -1; } static void xen_9pfs_alloc(struct XenDevice *xendev) { + xenstore_write_be_str(xendev, "versions", VERSIONS); + xenstore_write_be_int(xendev, "max-rings", MAX_RINGS); + xenstore_write_be_int(xendev, "max-ring-page-order", MAX_RING_ORDER); } static void xen_9pfs_disconnect(struct XenDevice *xendev) { + /* Dynamic hotplug of PV filesystems at runtime is not supported. */ } struct XenDevOps xen_9pfs_ops = { -- 1.9.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stefano Stabellini Subject: [PATCH v2 5/9] xen/9pfs: connect to the frontend Date: Mon, 13 Mar 2017 16:55:56 -0700 Message-ID: <1489449360-14411-5-git-send-email-sstabellini@kernel.org> References: <1489449360-14411-1-git-send-email-sstabellini@kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mail6.bemta6.messagelabs.com ([193.109.254.103]) by lists.xenproject.org with esmtp (Exim 4.84_2) (envelope-from ) id 1cnZp1-0007vA-Gy for xen-devel@lists.xenproject.org; Mon, 13 Mar 2017 23:56:15 +0000 In-Reply-To: <1489449360-14411-1-git-send-email-sstabellini@kernel.org> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Errors-To: xen-devel-bounces@lists.xen.org Sender: "Xen-devel" To: qemu-devel@nongnu.org Cc: jgross@suse.com, sstabellini@kernel.org, groug@kaod.org, Stefano Stabellini , "Aneesh Kumar K.V" , anthony.perard@citrix.com, xen-devel@lists.xenproject.org List-Id: xen-devel@lists.xenproject.org V3JpdGUgdGhlIGxpbWl0cyBvZiB0aGUgYmFja2VuZCB0byB4ZW5zdG9yZS4gQ29ubmVjdCB0byB0 aGUgZnJvbnRlbmQuClVwb24gY29ubmVjdGlvbiwgYWxsb2NhdGUgdGhlIHJpbmdzIGFjY29yZGlu ZyB0byB0aGUgcHJvdG9jb2wKc3BlY2lmaWNhdGlvbi4KCkluaXRpYWxpemUgYSBRRU1VQkggdG8g c2NoZWR1bGUgd29yayB1cG9uIHJlY2VpdmluZyBhbiBldmVudCBjaGFubmVsCm5vdGlmaWNhdGlv biBmcm9tIHRoZSBmcm9udGVuZC4KClNpZ25lZC1vZmYtYnk6IFN0ZWZhbm8gU3RhYmVsbGluaSA8 c3RlZmFub0BhcG9yZXRvLmNvbT4KQ0M6IGFudGhvbnkucGVyYXJkQGNpdHJpeC5jb20KQ0M6IGpn cm9zc0BzdXNlLmNvbQpDQzogQW5lZXNoIEt1bWFyIEsuViA8YW5lZXNoLmt1bWFyQGxpbnV4LnZu ZXQuaWJtLmNvbT4KQ0M6IEdyZWcgS3VyeiA8Z3JvdWdAa2FvZC5vcmc+Ci0tLQogaHcvOXBmcy94 ZW4tOXAtYmFja2VuZC5jIHwgMTU5ICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysr KysrKysrKysrKystCiAxIGZpbGUgY2hhbmdlZCwgMTU4IGluc2VydGlvbnMoKyksIDEgZGVsZXRp b24oLSkKCmRpZmYgLS1naXQgYS9ody85cGZzL3hlbi05cC1iYWNrZW5kLmMgYi9ody85cGZzL3hl bi05cC1iYWNrZW5kLmMKaW5kZXggMzUwMzJkMy4uMGU0YTEzMyAxMDA2NDQKLS0tIGEvaHcvOXBm cy94ZW4tOXAtYmFja2VuZC5jCisrKyBiL2h3LzlwZnMveGVuLTlwLWJhY2tlbmQuYwpAQCAtMTcs OCArMTcsMzUgQEAKICNpbmNsdWRlICJxZW11L2NvbmZpZy1maWxlLmgiCiAjaW5jbHVkZSAiZnNk ZXYvcWVtdS1mc2Rldi5oIgogCisjZGVmaW5lIFZFUlNJT05TICIxIgorI2RlZmluZSBNQVhfUklO R1MgOAorI2RlZmluZSBNQVhfUklOR19PUkRFUiA4CisKK3N0cnVjdCBYZW45cGZzUmluZyB7Cisg ICAgc3RydWN0IFhlbjlwZnNEZXYgKnByaXY7CisKKyAgICBpbnQgcmVmOworICAgIHhlbmV2dGNo bl9oYW5kbGUgICAqZXZ0Y2huZGV2OworICAgIGludCBldnRjaG47CisgICAgaW50IGxvY2FsX3Bv cnQ7CisgICAgc3RydWN0IHhlbl85cGZzX2RhdGFfaW50ZiAqaW50ZjsKKyAgICB1bnNpZ25lZCBj aGFyICpkYXRhOworICAgIHN0cnVjdCB4ZW5fOXBmc19kYXRhIHJpbmc7CisKKyAgICBRRU1VQkgg KmJoOworCisgICAgLyogbG9jYWwgY29waWVzLCBzbyB0aGF0IHdlIGNhbiByZWFkL3dyaXRlIFBE VSBkYXRhIGRpcmVjdGx5IGZyb20KKyAgICAgKiB0aGUgcmluZyAqLworICAgIFJJTkdfSURYIG91 dF9jb25zLCBvdXRfc2l6ZSwgaW5fY29uczsKKyAgICBib29sIGlucHJvZ3Jlc3M7Cit9OworCiB0 eXBlZGVmIHN0cnVjdCBYZW45cGZzRGV2IHsKICAgICBzdHJ1Y3QgWGVuRGV2aWNlIHhlbmRldjsg IC8qIG11c3QgYmUgZmlyc3QgKi8KKyAgICBWOWZzU3RhdGUgc3RhdGU7CisKKyAgICBpbnQgbnVt X3JpbmdzOworICAgIHN0cnVjdCBYZW45cGZzUmluZyAqcmluZ3M7CiB9IFhlbjlwZnNEZXY7CiAK IHN0YXRpYyBzc2l6ZV90IHhlbl85cGZzX3BkdV92bWFyc2hhbChWOWZzUERVICpwZHUsCkBAIC02 NywyMiArOTQsMTUyIEBAIHN0YXRpYyBpbnQgeGVuXzlwZnNfaW5pdChzdHJ1Y3QgWGVuRGV2aWNl ICp4ZW5kZXYpCiAgICAgcmV0dXJuIDA7CiB9CiAKK3N0YXRpYyB2b2lkIHhlbl85cGZzX2JoKHZv aWQgKm9wYXF1ZSkKK3sKK30KKworc3RhdGljIHZvaWQgeGVuXzlwZnNfZXZ0Y2huX2V2ZW50KHZv aWQgKm9wYXF1ZSkKK3sKK30KKwogc3RhdGljIGludCB4ZW5fOXBmc19mcmVlKHN0cnVjdCBYZW5E ZXZpY2UgKnhlbmRldikKIHsKLSAgICByZXR1cm4gLTE7CisgICAgaW50IGk7CisgICAgc3RydWN0 IFhlbjlwZnNEZXYgKnhlbl85cGRldiA9IGNvbnRhaW5lcl9vZih4ZW5kZXYsIHN0cnVjdCBYZW45 cGZzRGV2LCB4ZW5kZXYpOworCisgICAgZm9yIChpID0gMDsgaSA8IHhlbl85cGRldi0+bnVtX3Jp bmdzOyBpKyspIHsKKyAgICAgICAgaWYgKHhlbl85cGRldi0+cmluZ3NbaV0uZGF0YSAhPSBOVUxM KSB7CisgICAgICAgICAgICB4ZW5nbnR0YWJfdW5tYXAoeGVuXzlwZGV2LT54ZW5kZXYuZ250dGFi ZGV2LAorICAgICAgICAgICAgICAgICAgICB4ZW5fOXBkZXYtPnJpbmdzW2ldLmRhdGEsCisgICAg ICAgICAgICAgICAgICAgICgxIDw8IFhFTl85UEZTX1JJTkdfT1JERVIpKTsKKyAgICAgICAgfQor ICAgICAgICBpZiAoeGVuXzlwZGV2LT5yaW5nc1tpXS5pbnRmICE9IE5VTEwpIHsKKyAgICAgICAg ICAgIHhlbmdudHRhYl91bm1hcCh4ZW5fOXBkZXYtPnhlbmRldi5nbnR0YWJkZXYsCisgICAgICAg ICAgICAgICAgICAgIHhlbl85cGRldi0+cmluZ3NbaV0uaW50ZiwKKyAgICAgICAgICAgICAgICAg ICAgMSk7CisgICAgICAgIH0KKyAgICAgICAgaWYgKHhlbl85cGRldi0+cmluZ3NbaV0uZXZ0Y2hu ZGV2ID4gMCkgeworICAgICAgICAgICAgcWVtdV9zZXRfZmRfaGFuZGxlcih4ZW5ldnRjaG5fZmQo eGVuXzlwZGV2LT5yaW5nc1tpXS5ldnRjaG5kZXYpLAorICAgICAgICAgICAgICAgICAgICBOVUxM LCBOVUxMLCBOVUxMKTsKKyAgICAgICAgICAgIHhlbmV2dGNobl91bmJpbmQoeGVuXzlwZGV2LT5y aW5nc1tpXS5ldnRjaG5kZXYsIHhlbl85cGRldi0+cmluZ3NbaV0ubG9jYWxfcG9ydCk7CisgICAg ICAgIH0KKyAgICAgICAgaWYgKHhlbl85cGRldi0+cmluZ3NbaV0uYmggIT0gTlVMTCkgeworICAg ICAgICAgICAgcWVtdV9iaF9kZWxldGUoeGVuXzlwZGV2LT5yaW5nc1tpXS5iaCk7CisgICAgICAg IH0KKyAgICB9CisgICAgZ19mcmVlKHhlbl85cGRldi0+cmluZ3MpOworICAgIHJldHVybiAwOwog fQogCiBzdGF0aWMgaW50IHhlbl85cGZzX2Nvbm5lY3Qoc3RydWN0IFhlbkRldmljZSAqeGVuZGV2 KQogeworICAgIGludCBpOworICAgIHN0cnVjdCBYZW45cGZzRGV2ICp4ZW5fOXBkZXYgPSBjb250 YWluZXJfb2YoeGVuZGV2LCBzdHJ1Y3QgWGVuOXBmc0RldiwgeGVuZGV2KTsKKyAgICBWOWZzU3Rh dGUgKnMgPSAmeGVuXzlwZGV2LT5zdGF0ZTsKKyAgICBRZW11T3B0cyAqZnNkZXY7CisgICAgY2hh ciAqc2VjdXJpdHlfbW9kZWwsICpwYXRoOworCisgICAgaWYgKHhlbnN0b3JlX3JlYWRfZmVfaW50 KCZ4ZW5fOXBkZXYtPnhlbmRldiwgIm51bS1yaW5ncyIsCisgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICZ4ZW5fOXBkZXYtPm51bV9yaW5ncykgPT0gLTEgfHwKKyAgICAgICAgeGVuXzlwZGV2 LT5udW1fcmluZ3MgPiBNQVhfUklOR1MpIHsKKyAgICAgICAgcmV0dXJuIC0xOworICAgIH0KKwor ICAgIHhlbl85cGRldi0+cmluZ3MgPSBnX21hbGxvYzAoeGVuXzlwZGV2LT5udW1fcmluZ3MgKiBz aXplb2Yoc3RydWN0IFhlbjlwZnNSaW5nKSk7CisgICAgZm9yIChpID0gMDsgaSA8IHhlbl85cGRl di0+bnVtX3JpbmdzOyBpKyspIHsKKyAgICAgICAgY2hhciBzdHJbMTZdOworCisgICAgICAgIHhl bl85cGRldi0+cmluZ3NbaV0ucHJpdiA9IHhlbl85cGRldjsKKyAgICAgICAgeGVuXzlwZGV2LT5y aW5nc1tpXS5ldnRjaG4gPSAtMTsKKyAgICAgICAgeGVuXzlwZGV2LT5yaW5nc1tpXS5sb2NhbF9w b3J0ID0gLTE7CisKKyAgICAgICAgc3ByaW50ZihzdHIsICJyaW5nLXJlZiV1IiwgaSk7CisgICAg ICAgIGlmICh4ZW5zdG9yZV9yZWFkX2ZlX2ludCgmeGVuXzlwZGV2LT54ZW5kZXYsIHN0ciwKKyAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICZ4ZW5fOXBkZXYtPnJpbmdzW2ldLnJlZikg PT0gLTEpIHsKKyAgICAgICAgICAgIGdvdG8gb3V0OworICAgICAgICB9CisgICAgICAgIHNwcmlu dGYoc3RyLCAiZXZlbnQtY2hhbm5lbC0ldSIsIGkpOworICAgICAgICBpZiAoeGVuc3RvcmVfcmVh ZF9mZV9pbnQoJnhlbl85cGRldi0+eGVuZGV2LCBzdHIsCisgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAmeGVuXzlwZGV2LT5yaW5nc1tpXS5ldnRjaG4pID09IC0xKSB7CisgICAgICAg ICAgICBnb3RvIG91dDsKKyAgICAgICAgfQorCisgICAgICAgIHhlbl85cGRldi0+cmluZ3NbaV0u aW50ZiA9ICB4ZW5nbnR0YWJfbWFwX2dyYW50X3JlZigKKyAgICAgICAgICAgICAgICB4ZW5fOXBk ZXYtPnhlbmRldi5nbnR0YWJkZXYsCisgICAgICAgICAgICAgICAgeGVuXzlwZGV2LT54ZW5kZXYu ZG9tLAorICAgICAgICAgICAgICAgIHhlbl85cGRldi0+cmluZ3NbaV0ucmVmLAorICAgICAgICAg ICAgICAgIFBST1RfUkVBRCB8IFBST1RfV1JJVEUpOworICAgICAgICBpZiAoIXhlbl85cGRldi0+ cmluZ3NbaV0uaW50ZikgeworICAgICAgICAgICAgZ290byBvdXQ7CisgICAgICAgIH0KKyAgICAg ICAgeGVuXzlwZGV2LT5yaW5nc1tpXS5kYXRhID0geGVuZ250dGFiX21hcF9kb21haW5fZ3JhbnRf cmVmcygKKyAgICAgICAgICAgICAgICB4ZW5fOXBkZXYtPnhlbmRldi5nbnR0YWJkZXYsCisgICAg ICAgICAgICAgICAgKDEgPDwgWEVOXzlQRlNfUklOR19PUkRFUiksCisgICAgICAgICAgICAgICAg eGVuXzlwZGV2LT54ZW5kZXYuZG9tLAorICAgICAgICAgICAgICAgIHhlbl85cGRldi0+cmluZ3Nb aV0uaW50Zi0+cmVmLAorICAgICAgICAgICAgICAgIFBST1RfUkVBRCB8IFBST1RfV1JJVEUpOwor ICAgICAgICBpZiAoIXhlbl85cGRldi0+cmluZ3NbaV0uZGF0YSkgeworICAgICAgICAgICAgZ290 byBvdXQ7CisgICAgICAgIH0KKyAgICAgICAgeGVuXzlwZGV2LT5yaW5nc1tpXS5yaW5nLmluID0g eGVuXzlwZGV2LT5yaW5nc1tpXS5kYXRhOworICAgICAgICB4ZW5fOXBkZXYtPnJpbmdzW2ldLnJp bmcub3V0ID0geGVuXzlwZGV2LT5yaW5nc1tpXS5kYXRhICsgWEVOXzlQRlNfUklOR19TSVpFOwor CisgICAgICAgIHhlbl85cGRldi0+cmluZ3NbaV0uYmggPSBxZW11X2JoX25ldyh4ZW5fOXBmc19i aCwgJnhlbl85cGRldi0+cmluZ3NbaV0pOworICAgICAgICB4ZW5fOXBkZXYtPnJpbmdzW2ldLm91 dF9jb25zID0gMDsKKyAgICAgICAgeGVuXzlwZGV2LT5yaW5nc1tpXS5vdXRfc2l6ZSA9IDA7Cisg ICAgICAgIHhlbl85cGRldi0+cmluZ3NbaV0uaW5wcm9ncmVzcyA9IGZhbHNlOworCisKKyAgICAg ICAgeGVuXzlwZGV2LT5yaW5nc1tpXS5ldnRjaG5kZXYgPSB4ZW5ldnRjaG5fb3BlbihOVUxMLCAw KTsKKyAgICAgICAgaWYgKHhlbl85cGRldi0+cmluZ3NbaV0uZXZ0Y2huZGV2ID09IE5VTEwpIHsK KyAgICAgICAgICAgIGdvdG8gb3V0OworICAgICAgICB9CisgICAgICAgIGZjbnRsKHhlbmV2dGNo bl9mZCh4ZW5fOXBkZXYtPnJpbmdzW2ldLmV2dGNobmRldiksIEZfU0VURkQsIEZEX0NMT0VYRUMp OworICAgICAgICB4ZW5fOXBkZXYtPnJpbmdzW2ldLmxvY2FsX3BvcnQgPSB4ZW5ldnRjaG5fYmlu ZF9pbnRlcmRvbWFpbgorICAgICAgICAgICAgKHhlbl85cGRldi0+cmluZ3NbaV0uZXZ0Y2huZGV2 LCB4ZW5kZXYtPmRvbSwgeGVuXzlwZGV2LT5yaW5nc1tpXS5ldnRjaG4pOworICAgICAgICBpZiAo eGVuXzlwZGV2LT5yaW5nc1tpXS5sb2NhbF9wb3J0ID09IC0xKSB7CisgICAgICAgICAgICB4ZW5f cHZfcHJpbnRmKHhlbmRldiwgMCwgInhlbmV2dGNobl9iaW5kX2ludGVyZG9tYWluIGZhaWxlZCBw b3J0PSVkXG4iLAorICAgICAgICAgICAgICAgICAgICAgICAgICB4ZW5fOXBkZXYtPnJpbmdzW2ld LmV2dGNobik7CisgICAgICAgICAgICBnb3RvIG91dDsKKyAgICAgICAgfQorICAgICAgICB4ZW5f cHZfcHJpbnRmKHhlbmRldiwgMiwgImJpbmQgZXZ0Y2huIHBvcnQgJWRcbiIsIHhlbmRldi0+bG9j YWxfcG9ydCk7CisgICAgICAgIHFlbXVfc2V0X2ZkX2hhbmRsZXIoeGVuZXZ0Y2huX2ZkKHhlbl85 cGRldi0+cmluZ3NbaV0uZXZ0Y2huZGV2KSwKKyAgICAgICAgICAgICAgICB4ZW5fOXBmc19ldnRj aG5fZXZlbnQsIE5VTEwsICZ4ZW5fOXBkZXYtPnJpbmdzW2ldKTsKKyAgICB9CisKKyAgICBzZWN1 cml0eV9tb2RlbCA9IHhlbnN0b3JlX3JlYWRfYmVfc3RyKHhlbmRldiwgInNlY3VyaXR5X21vZGVs Iik7CisgICAgcGF0aCA9IHhlbnN0b3JlX3JlYWRfYmVfc3RyKHhlbmRldiwgInBhdGgiKTsKKyAg ICBzLT5mc2NvbmYuZnNkZXZfaWQgPSBnX21hbGxvYyhzdHJsZW4oInhlbjlwIikgKyA2KTsKKyAg ICBzcHJpbnRmKHMtPmZzY29uZi5mc2Rldl9pZCwgInhlbjlwJWQiLCB4ZW5kZXYtPmRldik7Cisg ICAgcy0+ZnNjb25mLnRhZyA9IHhlbnN0b3JlX3JlYWRfZmVfc3RyKHhlbmRldiwgInRhZyIpOwor ICAgIHY5ZnNfcmVnaXN0ZXJfdHJhbnNwb3J0KHMsICZ4ZW5fOXBfdHJhbnNwb3J0KTsKKyAgICBm c2RldiA9IHFlbXVfb3B0c19jcmVhdGUocWVtdV9maW5kX29wdHMoImZzZGV2IiksCisgICAgICAg ICAgICBzLT5mc2NvbmYudGFnLAorICAgICAgICAgICAgMSwgTlVMTCk7CisgICAgcWVtdV9vcHRf c2V0KGZzZGV2LCAiZnNkcml2ZXIiLCAibG9jYWwiLCBOVUxMKTsKKyAgICBxZW11X29wdF9zZXQo ZnNkZXYsICJwYXRoIiwgcGF0aCwgTlVMTCk7CisgICAgcWVtdV9vcHRfc2V0KGZzZGV2LCAic2Vj dXJpdHlfbW9kZWwiLCBzZWN1cml0eV9tb2RlbCwgTlVMTCk7CisgICAgcWVtdV9vcHRzX3NldF9p ZChmc2Rldiwgcy0+ZnNjb25mLmZzZGV2X2lkKTsKKyAgICBxZW11X2ZzZGV2X2FkZChmc2Rldik7 CisgICAgdjlmc19kZXZpY2VfcmVhbGl6ZV9jb21tb24ocywgTlVMTCk7CisKICAgICByZXR1cm4g MDsKKworb3V0OgorICAgIHhlbl85cGZzX2ZyZWUoeGVuZGV2KTsKKyAgICByZXR1cm4gLTE7CiB9 CiAKIHN0YXRpYyB2b2lkIHhlbl85cGZzX2FsbG9jKHN0cnVjdCBYZW5EZXZpY2UgKnhlbmRldikK IHsKKyAgICB4ZW5zdG9yZV93cml0ZV9iZV9zdHIoeGVuZGV2LCAidmVyc2lvbnMiLCBWRVJTSU9O Uyk7CisgICAgeGVuc3RvcmVfd3JpdGVfYmVfaW50KHhlbmRldiwgIm1heC1yaW5ncyIsIE1BWF9S SU5HUyk7CisgICAgeGVuc3RvcmVfd3JpdGVfYmVfaW50KHhlbmRldiwgIm1heC1yaW5nLXBhZ2Ut b3JkZXIiLCBNQVhfUklOR19PUkRFUik7CiB9CiAKIHN0YXRpYyB2b2lkIHhlbl85cGZzX2Rpc2Nv bm5lY3Qoc3RydWN0IFhlbkRldmljZSAqeGVuZGV2KQogeworICAgIC8qIER5bmFtaWMgaG90cGx1 ZyBvZiBQViBmaWxlc3lzdGVtcyBhdCBydW50aW1lIGlzIG5vdCBzdXBwb3J0ZWQuICovCiB9CiAK IHN0cnVjdCBYZW5EZXZPcHMgeGVuXzlwZnNfb3BzID0gewotLSAKMS45LjEKCgpfX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpYZW4tZGV2ZWwgbWFpbGluZyBs aXN0Clhlbi1kZXZlbEBsaXN0cy54ZW4ub3JnCmh0dHBzOi8vbGlzdHMueGVuLm9yZy94ZW4tZGV2 ZWwK