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 Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id BFF19C43219 for ; Fri, 21 Oct 2022 08:27:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=1pZJMLNM7qp+kD9v2Fq/uDtVRcUhcF2n17+LllKFpe4=; b=wTC4RU/FqL+Sm6 BMwqyn8wE7wQLqJDAQ88Dlwh6x8d3pK8dLURxBmrPmo7qxMXOEDm5965bnT8q6d2oQvTYl/QsHdyE YmDFc3Y4DK5XrynKbbfyrh1OwEJTetfi3cPenHtSt2hl0PZM0NmUIju5LR1Ds+IptvVs4WtD8D4UH 92JtqTT0+IE1dbXYONaHPGp8Axl4uj60zgB9K1L+9mOChyQ6nCBhS69UuLjU8sbrNkiiXhPR//Sl5 nDn8sMheYXBXteflRLundEw6n/TDaqXDm4mgnqLq571a6X99+MHVczNDrPLGHPLE4S9AJ+rW9Gf0D rbLKFGI97Lum+iGyXqmg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1olnMN-006Ktx-Kv; Fri, 21 Oct 2022 08:26:31 +0000 Received: from sin.source.kernel.org ([145.40.73.55]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1olnMJ-006KrU-91 for linux-arm-kernel@lists.infradead.org; Fri, 21 Oct 2022 08:26:29 +0000 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sin.source.kernel.org (Postfix) with ESMTPS id 529FDCE2A1B; Fri, 21 Oct 2022 08:26:23 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 8FE65C433C1; Fri, 21 Oct 2022 08:26:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1666340781; bh=t96neusjtVw7AQjAlsFggmE7+zhUoCI2GVkrlHER7Uo=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=sJCbGz88BhMZZ9QTKFDfSvOsgECd8EsClAxN7pnaPx8q/QzQpSYv0hBW94+xOID31 E7CUs6hJNbGuZ2MSIqPYEjAZwa4LNehysnbhHdeNV1n+fSpauSZCRNcV6bRSBOt+WV vC4h2N30Npz9UzFoZgvhqQueHKcsH2D42tGqRoKIWCzA5h1bFvEzs4K+17JBlXdT7w jbMKpswX3AJymB4zcvb00uwQEzXbne561qqJrc0JTlbA+ztlATlSIUAPIN940R7OjD Y1OTzt3MEAmUoLbIuIJxJdvodWyj9+yaDqr91DONmmO2Gv/2CFAlEcX9X/iyh1NHRu vOsd9XjVEJjZQ== Date: Fri, 21 Oct 2022 10:26:15 +0200 From: Lorenzo Pieralisi To: Elad Nachman Cc: Pali =?iso-8859-1?Q?Roh=E1r?= , Bjorn Helgaas , Krzysztof =?utf-8?Q?Wilczy=C5=84ski?= , "linux-pci@vger.kernel.org" , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" Subject: Re: [EXT] Re: [PATCH v2] PCI: aardvark: Implement workaround for PCIe Completion Timeout Message-ID: References: <20220802123816.21817-1-pali@kernel.org> <20220926123434.2tqx4t6u3cnlrcx3@pali> <20221003211412.5pqfjvcxyszd4ai6@pali> <20221004083957.qtfkn4eyi42lsd4j@pali> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20221021_012627_720180_BC64CF7B X-CRM114-Status: GOOD ( 68.80 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org T24gVGh1LCBPY3QgMDYsIDIwMjIgYXQgMDg6MTQ6NDhBTSArMDAwMCwgRWxhZCBOYWNobWFuIHdy b3RlOgo+IEhpLAo+IAo+IFJlZ2FyZGluZyBudW1iZXIgIzEgOgo+IFRoZSBIL1cgZXJyYXR1bSBt ZWFucyBzdHJvbmcgb3JkZXJpbmcgbW9kZSBpcyBub3QgcHJvcGVybHkgaW1wbGVtZW50ZWQKPiBp biB0aGUgSC9XLiAgVGhlIHdvcmthcm91bmQgaXMgdG8gc2V0IERJU19PUkRfQ0hLIHRvIGRpc2Fi bGUgdGhlCj4gb3JkZXJlZCBjaGVjaywgdG8gcHJldmVudCB0aGUgaXNzdWVzIFBhbGkgbWVudGlv bmVkLiAgTGVhdmluZyBpdAo+IHdpdGhvdXQgdGhlIHdvcmthcm91bmQgbWVhbnMgZW5jb3VudGVy aW5nIHRoZSBjcmFzaGVzIFBhbGkgbWVudGlvbmVkLgo+IFRoZSBIL1cgd2FzIG9yaWdpbmFsbHkg ZGVzaWduZWQgdG8gaGF2ZSB0aGUgc3Ryb25nIG9yZGVyaW5nIG1vZGUsIHBlcgo+IHdoYXQgaXMg ZXhwZWN0ZWQgb2YgUENJIEV4cHJlc3MsIGJ1dCBkdWUgdG8gdGhpcyBlcnJhdHVtLCBpdCBjYW5u b3QgYmUKPiBzdXBwb3J0ZWQgYnkgdGhlIHRhcGVkLW91dCBIL1cuICBUaGVyZSBpcyBub3RoaW5n IHRvIGRvIGFib3V0IGl0IG5vdwo+IGluIHRoZSBIL1csIGFzIHRoaXMgaXMgYSB5ZWFycyBvbGQg U09DLiAgU29mdHdhcmUgd2lzZSB0aGUgb25seSBvcHRpb24KPiBpcyB0aGUgd29ya2Fyb3VuZCBh Ym92ZSwgb3IgdG8gYWNjZXB0IHNwb3JhZGljIGNyYXNoZXMgb2YgdGhlIGtlcm5lbC4KCkl0IGNh biBmaXggYSBkcml2ZXIsIGl0IGNhbiBicmVhayBhbm90aGVyIG9uZSAtIHRoZSBQQ0kgb3JkZXJp bmcgbW9kZWwKaXMgYnJva2VuIG9uZSB3YXkgb3IgYW5vdGhlci4KCkkgaGF2ZSBubyB3YXkgdG8g ZGV0ZXJtaW5lIHdoYXQgc2V0dGluZyBESVNfT1JEX0NISyBkb2VzIGFuZCB3aGF0IGl0CmltcGxp ZXMuCgpXaGF0IEkga25vdyBpcyB0aGF0IHdlIGFyZSBzZW5kaW5nIHRoaXMgcGF0Y2ggdG8gc3Rh YmxlIGtlcm5lbHMKYW5kIEkgd2FudCB0byBtYWtlIHN1cmUgYSkgaXQgd2FzIHRob3JvdWdobHkg dGVzdGVkIG9uIHNldmVyYWwKUENJIGVuZHBvaW50cyBhbmQgYikgaXQgaXMgcHJvcGVybHkgZG9j dW1lbnRlZC4KCj4gVGhlIGltcGFjdCBvZiB0aGUgd29ya2Fyb3VuZCBpcyB0aGF0IHRoZSBETUEg ZG9uZSBzdGF0dXMgY291bGQgYmUgc2V0Cj4gYmVmb3JlIHRoZSBsYXN0IGRhdGEgaXMgd3JpdHRl biB0byB0aGUgaG9zdCBtZW1vcnksIGNhdXNpbmcgdGhlIGhvc3QKPiB0byByZWFkIGluY29tcGxl dGUgZGF0YS4gVGhpcyBpcyB0aGUgcmVhc29uIHdoeSBJIHJlY29tbWVuZGVkIHRvIGFkZCBhCj4g bWVtb3J5IGJhcnJpZXIuIElmIHRoaXMgaXMgYm90aGVyaW5nLCB0aGUgbWVtb3J5IGJhcnJpZXIg Y2FuIGJlCj4gcmVtb3ZlZCBmcm9tIHRoZSBwYXRjaCwgYWx0aG91Z2ggSSBzdWdnZXN0IHRvIHRo b3JvdWdobHkgdGVzdCB0aGUgZGF0YQo+IGludGVncml0eSBpZiBpbXBsZW1lbnRpbmcgdGhlIHBh dGNoIHdpdGhvdXQgdGhlIG1lbW9yeSBiYXJyaWVyLgoKSXQgaXMgbm90IGJvdGhlcmluZywgaXQg aXMgdGhhdCBldmVyeSBtYigpIG11c3QgYmUgZXhwbGFpbmVkIGluIGRlcHRoLgoKV2UgYXJlIGFk ZGluZyBhbiBtYigpIGluIHRoZSAqY29udHJvbGxlciogaW50ZXJydXB0IGhhbmRsZXIuCgpJIGFz c3VtZSB0aGlzIGlzIGJlY2F1c2UgdGhhdCdzIHdoZXJlIHRoZSBETUEgY29tcGxldGlvbiBJUlEg aXMgcmFpc2VkCmFuZCB0aGVyZSB3ZSBpc3N1ZSBhbiBtYigpIHRvIG1ha2Ugc3VyZSB0aGF0IGVu ZHBvaW50IHdyaXRlcyBpbnRvCm1lbW9yeSBjb21wbGV0ZWQuCgpJZiB0aGF0J3MgY29ycmVjdCwg SSBoYXZlIG5vIGlkZWEgaG93IHRoZSBiYXJyaWVyIHBsYXlzIHRvZ2V0aGVyCndpdGggRElTX09S RF9DSEsgYWJvdmUuIFRoZSBtYigpIGhhcyBubyBlZmZlY3Qgb24gUENJIHdyaXRlcyBxdWV1ZWQK aW4gdGhlIFBDSSBidXMsIHNvIGl0IG1heSBiZSBhIHBsYXN0ZXIgYnV0IG5vdCBhIGZpeC4KCkkg d291bGQgbGlrZSB0byBoYXZlIGEgZnVsbCBkZXNjcmlwdGlvbiBvZiB3aGF0IHRoYXQgbWIoKSBp cyBzdXBwb3NlZAp0byBmaXggLSBpbiBkZXRhaWxzLgoKV2hlbiB3ZSBhZ3JlZSBpdCBpcyBmaXhp bmcgc29tZXRoaW5nIHdlIGNhbiBhZGQgYSBkZXNjcmlwdGl2ZSBjb21tZW50CndpdGggdGhlIG1i KCkgYW5kIG1lcmdlIHRoZSBjb2RlLgoKVGhhbmtzLApMb3JlbnpvCgo+IEZZSSwKPiAKPiBFbGFk Lgo+IAo+IC0tLS0tT3JpZ2luYWwgTWVzc2FnZS0tLS0tCj4gRnJvbTogUGFsaSBSb2jDoXIgPHBh bGlAa2VybmVsLm9yZz4gCj4gU2VudDogVHVlc2RheSwgT2N0b2JlciA0LCAyMDIyIDExOjQwIEFN Cj4gVG86IEVsYWQgTmFjaG1hbiA8ZW5hY2htYW5AbWFydmVsbC5jb20+OyBMb3JlbnpvIFBpZXJh bGlzaSA8bHBpZXJhbGlzaUBrZXJuZWwub3JnPgo+IENjOiBCam9ybiBIZWxnYWFzIDxiaGVsZ2Fh c0Bnb29nbGUuY29tPjsgS3J6eXN6dG9mIFdpbGN6ecWEc2tpIDxrd0BsaW51eC5jb20+OyBsaW51 eC1wY2lAdmdlci5rZXJuZWwub3JnOyBsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5v cmc7IGxpbnV4LWtlcm5lbEB2Z2VyLmtlcm5lbC5vcmcKPiBTdWJqZWN0OiBSZTogW0VYVF0gUmU6 IFtQQVRDSCB2Ml0gUENJOiBhYXJkdmFyazogSW1wbGVtZW50IHdvcmthcm91bmQgZm9yIFBDSWUg Q29tcGxldGlvbiBUaW1lb3V0Cj4gCj4gKyBFbGFkCj4gCj4gQ291bGQgeW91IHBsZWFzZSBsb29r IGF0IExvcmVuem8ncyBjb21tZW50cyBhbmQgaGVscCB3aXRoIHRoaXMgZml4Pwo+IAo+IE9uIFR1 ZXNkYXkgMDQgT2N0b2JlciAyMDIyIDEwOjAyOjMyIExvcmVuem8gUGllcmFsaXNpIHdyb3RlOgo+ ID4gT24gTW9uLCBPY3QgMDMsIDIwMjIgYXQgMTE6MTQ6MTJQTSArMDIwMCwgUGFsaSBSb2jDoXIg d3JvdGU6Cj4gPiA+IExvcmVuem8sIGlzIHNvbWV0aGluZyBtb3JlIG5lZWRlZCBmb3IgdGhpcyBw YXRjaD8gQXMgaXQgd29ya2Fyb3VuZHMgCj4gPiA+IGNyYXNoaW5nIGl0IGlzIHJlYWxseSBuZWVk ZWQgdG8gaGF2ZSBpdCBpbiBtYWlubGluZSBhbmQgYmFja3BvcnRzLgo+ID4gCj4gPiBZZXMsIGEg Y2xlYXIgZXhwbGFuYXRpb24gZnJvbSBNYXJ2ZWxsIGFib3V0IHdoYXQgdGhpcyBpcyBhY3R1YWxs eSAKPiA+IGZpeGluZyAtIGl0IHRvb2sgbWUgYSB3aGlsZSB0byBnbyB0aHJvdWdoIHRoZSB3aG9s ZSB0aHJlYWQgYnV0IEkgc3RpbGwgCj4gPiBkb24ndCB1bmRlcnN0YW5kIHdoYXQgdGhpcyBwYXRj aCBhY3R1YWxseSBkb2VzIGFuZCB3aHkuCj4gPiAKPiA+IEFuIEVycmF0dW0gd29ya2Fyb3VuZCAo aWYgdGhlcmUgaXMgYW55KSBzaG91bGQgZGVmaW5lIGFuZCBleHBsYWluIGEgU1cgCj4gPiB3b3Jr YXJvdW5kLgo+ID4gCj4gPiAoMSkgQmpvcm4ncyBjb25jZXJucyBpbiByZWxhdGlvbiB0byBQQ0kg bWVtb3J5IG1vZGVsIHdlcmVuJ3QgYWRkcmVzc2VkCj4gPiAoMikgV2UgZG9uJ3QgYWRkIHVuZG9j dW1lbnRlZCBtZW1vcnkgYmFycmllcnMgdG8gdGhlIGtlcm5lbCB0byAibWluaW1pemUKPiA+ICAg ICByaXNrcyIuIEVpdGhlciB3ZSBmaXggYSBidWcgb3Igd2UgZG9uJ3QuIElmIHdlIGRvLCB3cml0 ZSB0aGF0IGRvd24KPiA+ICAgICBhbmQgZG9jdW1lbnQgd2h5IHRoZSBiYXJyaWVyIGlzIHRoZXJl IGFuZCB0aGUgaXNzdWUgaXQgc29sdmVzLgo+ID4gCj4gPiBJIHVuZGVyc3RhbmQgdGhhdCBiYXNp Y2FsbHkgeW91IGFyZSByZXZlcnNlIGVuZ2luZWVyaW5nIGEgSFcgYnVnIGJ1dCBJIAo+ID4gYW0g YWZyYWlkIHdlIGNhbid0IGZpeCB0aGUga2VybmVsIHRoaXMgd2F5IC0gbW9yZSBzbyB3aXRoIHBh dGNoZXMgCj4gPiBnb2luZyB0byBiZSBiYWNrcG9ydGVkIHRvIHN0YWJsZSBrZXJuZWxzLgo+ID4g Cj4gPiBMb3JlbnpvCj4gPiAKPiA+ID4gT24gV2VkbmVzZGF5IDI4IFNlcHRlbWJlciAyMDIyIDE0 OjA1OjEwIEVsYWQgTmFjaG1hbiB3cm90ZToKPiA+ID4gPiBSZXZpZXdlZC1ieTogRWxhZCBOYWNo bWFuIDxlbmFjaG1hbkBtYXJ2ZWxsLmNvbT4KPiA+ID4gPiAKPiA+ID4gPiBUaGFua3MsCj4gPiA+ ID4gCj4gPiA+ID4gRWxhZC4KPiA+ID4gPiAKPiA+ID4gPiAtLS0tLU9yaWdpbmFsIE1lc3NhZ2Ut LS0tLQo+ID4gPiA+IEZyb206IFBhbGkgUm9ow6FyIDxwYWxpQGtlcm5lbC5vcmc+Cj4gPiA+ID4g U2VudDogTW9uZGF5LCBTZXB0ZW1iZXIgMjYsIDIwMjIgMzozNSBQTQo+ID4gPiA+IFRvOiBFbGFk IE5hY2htYW4gPGVuYWNobWFuQG1hcnZlbGwuY29tPgo+ID4gPiA+IENjOiBUaG9tYXMgUGV0YXp6 b25pIDx0aG9tYXMucGV0YXp6b25pQGJvb3RsaW4uY29tPjsgTG9yZW56byAKPiA+ID4gPiBQaWVy YWxpc2kgPGxwaWVyYWxpc2lAa2VybmVsLm9yZz47IEJqb3JuIEhlbGdhYXMgCj4gPiA+ID4gPGJo ZWxnYWFzQGdvb2dsZS5jb20+OyBLcnp5c3p0b2YgV2lsY3p5xYRza2kgPGt3QGxpbnV4LmNvbT47 IFJvYiAKPiA+ID4gPiBIZXJyaW5nIDxyb2JoQGtlcm5lbC5vcmc+OyBsaW51eC1wY2lAdmdlci5r ZXJuZWwub3JnOyAKPiA+ID4gPiBsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5vcmc7 IAo+ID4gPiA+IGxpbnV4LWtlcm5lbEB2Z2VyLmtlcm5lbC5vcmc7IEdyZWdvcnkgQ2xlbWVudCAK PiA+ID4gPiA8Z3JlZ29yeS5jbGVtZW50QGJvb3RsaW4uY29tPjsgTWFyZWsgQmVow7puIDxrYWJl bEBrZXJuZWwub3JnPjsgCj4gPiA+ID4gUmVtaSBQb21tYXJlbCA8cmVwa0B0cmlwbGVmYXUubHQ+ OyBYb2dpdW0gPGNvbnRhY3RAeG9naXVtLm1lPjsgCj4gPiA+ID4gVG9tYXN6IE1hY2llaiBOb3dh ayA8dG1uNTA1QGdtYWlsLmNvbT4KPiA+ID4gPiBTdWJqZWN0OiBbRVhUXSBSZTogW1BBVENIIHYy XSBQQ0k6IGFhcmR2YXJrOiBJbXBsZW1lbnQgd29ya2Fyb3VuZCAKPiA+ID4gPiBmb3IgUENJZSBD b21wbGV0aW9uIFRpbWVvdXQKPiA+ID4gPiAKPiA+ID4gPiBFeHRlcm5hbCBFbWFpbAo+ID4gPiA+ IAo+ID4gPiA+IC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLQo+ID4gPiA+IC0tLS0gSGVsbG8gRWxhZCwgY291bGQgeW91IHBs ZWFzZSByZXZpZXcgdGhpcyBwYXRjaD8gSSBoYXZlIAo+ID4gPiA+IGltcGxlbWVudGVkIGl0IGFj Y29yZGluZyB5b3VyIGluc3RydWN0aW9ucywgaW5jbHVkaW5nIHRoYXQgZnVsbCBtZW1vcnkgYmFy cmllciBhcyB5b3UgZGVzY3JpYmVkLgo+ID4gPiA+IAo+ID4gPiA+IE9uIFR1ZXNkYXkgMDIgQXVn dXN0IDIwMjIgMTQ6Mzg6MTYgUGFsaSBSb2jDoXIgd3JvdGU6Cj4gPiA+ID4gPiBNYXJ2ZWxsIEFy bWFkYSAzNzAwIEZ1bmN0aW9uYWwgRXJyYXRhLCBHdWlkZWxpbmVzLCBhbmQgCj4gPiA+ID4gPiBS ZXN0cmljdGlvbnMgZG9jdW1lbnQgZGVzY3JpYmVzIGluIGVycmF0dW0gMy4xMiBQQ0llIENvbXBs ZXRpb24gVGltZW91dCAoUmVmICM6Cj4gPiA+ID4gPiAyNTEpLCB0aGF0IFBDSWUgSVAgZG9lcyBu b3Qgc3VwcG9ydCBhIHN0cm9uZy1vcmRlcmVkIG1vZGVsIGZvciBpbmJvdW5kIHBvc3RlZCB2cy4K PiA+ID4gPiA+IG91dGJvdW5kIGNvbXBsZXRpb24uCj4gPiA+ID4gPiAKPiA+ID4gPiA+IEFzIGEg d29ya2Fyb3VuZCBmb3IgdGhpcyBlcnJhdHVtLCBESVNfT1JEX0NISyBmbGFnIGluIERlYnVnIE11 eCAKPiA+ID4gPiA+IENvbnRyb2wgcmVnaXN0ZXIgbXVzdCBiZSBzZXQuIEl0IGRpc2FibGVzIHRo ZSBvcmRlcmluZyBjaGVjayBpbiAKPiA+ID4gPiA+IHRoZSBjb3JlIGJldHdlZW4gQ29tcGxldGlv bnMgYW5kIFBvc3RlZCByZXF1ZXN0cyByZWNlaXZlZCBmcm9tIHRoZSBsaW5rLgo+ID4gPiA+ID4g Cj4gPiA+ID4gPiBNYXJ2ZWxsIGFsc28gc3VnZ2VzdHMgdG8gZG8gZnVsbCBtZW1vcnkgYmFycmll ciBhdCB0aGUgYmVnaW5uaW5nIAo+ID4gPiA+ID4gb2YgYWFyZHZhcmsgc3VtbWFyeSBpbnRlcnJ1 cHQgaGFuZGxlciBiZWZvcmUgY2FsbGluZyBpbnRlcnJ1cHQgCj4gPiA+ID4gPiBoYW5kbGVycyBv ZiBlbmRwb2ludCBkcml2ZXJzIGluIG9yZGVyIHRvIG1pbmltaXplIHRoZSByaXNrIGZvciAKPiA+ ID4gPiA+IHRoZSByYWNlIGNvbmRpdGlvbiBkb2N1bWVudGVkIGluIHRoZSBFcnJhdHVtIGJldHdl ZW4gdGhlIERNQSAKPiA+ID4gPiA+IGRvbmUgc3RhdHVzIHJlYWRpbmcgYW5kIHRoZSBjb21wbGV0 aW9uIG9mIHdyaXRpbmcgdG8gdGhlIGhvc3QgbWVtb3J5Lgo+ID4gPiA+ID4gCj4gPiA+ID4gPiBN b3JlIGRldGFpbHMgYWJvdXQgdGhpcyBpc3N1ZSBhbmQgc3VnZ2VzdGVkIHdvcmthcm91bmRzIGFy ZSBpbiBkaXNjdXNzaW9uOgo+ID4gPiA+ID4gaHR0cHM6Ly91cmxkZWZlbnNlLnByb29mcG9pbnQu Y29tL3YyL3VybD91PWh0dHBzLTNBX19sb3JlLmtlcm5lbAo+ID4gPiA+ID4gLm9yZ19sIAo+ID4g PiA+ID4gaW51eC0yRHBjaV9CTjlQUjE4TUI0MjUxNTRGRTUwMTlEQ0FGMjAyOEExRDVEQjhEOS00 MEJOOVBSMThNQjQyNQo+ID4gPiA+ID4gMS5uYW1wIAo+ID4gPiA+ID4gcmQxOC5wcm9kLm91dGxv b2suY29tX3RfLTIzdSZkPUR3SURhUSZjPW5LaldlYzJiNlIwbU95UGF6N3h0ZlEmcgo+ID4gPiA+ ID4gPWVUZU5UCj4gPiA+ID4gPiBMRUs1LVR4WGN6ak9jS1BoQU5JRnRsQjlwUDRscTlxaGRsRnJ3 USZtPWJqZ2toZ1BnT2pxQ0VzYkhZSE9OQ1pNCj4gPiA+ID4gPiBpRkRYNzIgCj4gPiA+ID4gPiBN enRXYUUwQXZXQmt0UVZuM3pLRUR0VWRuMDJLeF9LSjE0QiZzPVNUb0dzREdFT2J3YlpHaWxWdFZa UHlNRThqCj4gPiA+ID4gPiBOaVJncnEKPiA+ID4gPiA+IDRTRFl2cXFUMFRBJmU9Cj4gPiA+ID4g PiAKPiA+ID4gPiA+IEl0IHdhcyByZXBvcnRlZCB0aGF0IGVuYWJsaW5nIHRoaXMgd29ya2Fyb3Vu ZCBmaXhlcyBpbnN0YWJpbGl0eSAKPiA+ID4gPiA+IGlzc3VlcyBhbmQgIlVuaGFuZGxlZCBmYXVs dCIgZXJyb3JzIHdoZW4gdXNpbmcgNjAgR0h6IFdpRmkgCj4gPiA+ID4gPiA4MDIuMTFhZCBjYXJk IHdpdGggUXVhbGNvbW0KPiA+ID4gPiA+IFFDQTYzMzUgY2hpcCB1bmRlciBzaWduaWZpY2FudCBs b2FkIHdoaWNoIHdlcmUgY2F1c2VkIGJ5IAo+ID4gPiA+ID4gaW50ZXJydXB0IHN0YXR1cyBzdHVj ayBpbiB0aGUgb3V0Ym91bmQgQ01QTFQgcXVldWUgdHJhY2VkIGJhY2sgdG8gdGhpcyBlcnJhdHVt Lgo+ID4gPiA+ID4gCj4gPiA+ID4gPiBUaGlzIHdvcmthcm91bmQgZml4ZXMgYWxzbyBrZXJuZWwg cGFuaWMgdHJpZ2dlcmVkIGFmdGVyIHNvbWUgCj4gPiA+ID4gPiBtaW51dGVzIG9mIHVzYWdlIDUg R0h6IFdpRmkgODAyLjExYXggY2FyZCB3aXRoIE1lZGlhdGVrIE1UNzkxNSBjaGlwOgo+ID4gPiA+ ID4gCj4gPiA+ID4gPiAgICAgSW50ZXJuYWwgZXJyb3I6IHN5bmNocm9ub3VzIGV4dGVybmFsIGFi b3J0OiA5NjAwMDIxMCBbIzFdIFNNUAo+ID4gPiA+ID4gICAgIEtlcm5lbCBwYW5pYyAtIG5vdCBz eW5jaW5nOiBGYXRhbCBleGNlcHRpb24gaW4gaW50ZXJydXB0Cj4gPiA+ID4gPiAKPiA+ID4gPiA+ IFNpZ25lZC1vZmYtYnk6IFRob21hcyBQZXRhenpvbmkgPHRob21hcy5wZXRhenpvbmlAYm9vdGxp bi5jb20+Cj4gPiA+ID4gPiBTaWduZWQtb2ZmLWJ5OiBQYWxpIFJvaMOhciA8cGFsaUBrZXJuZWwu b3JnPgo+ID4gPiA+ID4gRml4ZXM6IDhjMzlkNzEwMzYzYyAoIlBDSTogYWFyZHZhcms6IEFkZCBB YXJkdmFyayBQQ0kgaG9zdCAKPiA+ID4gPiA+IGNvbnRyb2xsZXIKPiA+ID4gPiA+IGRyaXZlciIp Cj4gPiA+ID4gPiBDYzogc3RhYmxlQHZnZXIua2VybmVsLm9yZwo+ID4gPiA+ID4gLS0tCj4gPiA+ ID4gPiAgZHJpdmVycy9wY2kvY29udHJvbGxlci9wY2ktYWFyZHZhcmsuYyB8IDEwICsrKysrKysr KysKPiA+ID4gPiA+ICAxIGZpbGUgY2hhbmdlZCwgMTAgaW5zZXJ0aW9ucygrKQo+ID4gPiA+ID4g Cj4gPiA+ID4gPiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9wY2kvY29udHJvbGxlci9wY2ktYWFyZHZh cmsuYwo+ID4gPiA+ID4gYi9kcml2ZXJzL3BjaS9jb250cm9sbGVyL3BjaS1hYXJkdmFyay5jCj4g PiA+ID4gPiBpbmRleCAwNjA5MzZlZjAxZmUuLjNhZThhODVlYzcyZSAxMDA2NDQKPiA+ID4gPiA+ IC0tLSBhL2RyaXZlcnMvcGNpL2NvbnRyb2xsZXIvcGNpLWFhcmR2YXJrLmMKPiA+ID4gPiA+ICsr KyBiL2RyaXZlcnMvcGNpL2NvbnRyb2xsZXIvcGNpLWFhcmR2YXJrLmMKPiA+ID4gPiA+IEBAIC0y MTAsNiArMjEwLDggQEAgZW51bSB7Cj4gPiA+ID4gPiAgfTsKPiA+ID4gPiA+ICAKPiA+ID4gPiA+ ICAjZGVmaW5lIFZFTkRPUl9JRF9SRUcJCQkJKExNSV9CQVNFX0FERFIgKyAweDQ0KQo+ID4gPiA+ ID4gKyNkZWZpbmUgREVCVUdfTVVYX0NUUkxfUkVHCQkJKExNSV9CQVNFX0FERFIgKyAweDIwOCkK PiA+ID4gPiA+ICsjZGVmaW5lICAgICBESVNfT1JEX0NISwkJCQlCSVQoMzApCj4gPiA+ID4gPiAg Cj4gPiA+ID4gPiAgLyogUENJZSBjb3JlIGNvbnRyb2xsZXIgcmVnaXN0ZXJzICovCj4gPiA+ID4g PiAgI2RlZmluZSBDVFJMX0NPUkVfQkFTRV9BRERSCQkJMHgxODAwMAo+ID4gPiA+ID4gQEAgLTU1 OCw2ICs1NjAsMTEgQEAgc3RhdGljIHZvaWQgYWR2a19wY2llX3NldHVwX2h3KHN0cnVjdCBhZHZr X3BjaWUgKnBjaWUpCj4gPiA+ID4gPiAgCQlQQ0lFX0NPUkVfQ1RSTDJfVERfRU5BQkxFOwo+ID4g PiA+ID4gIAlhZHZrX3dyaXRlbChwY2llLCByZWcsIFBDSUVfQ09SRV9DVFJMMl9SRUcpOwo+ID4g PiA+ID4gIAo+ID4gPiA+ID4gKwkvKiBEaXNhYmxlIG9yZGVyaW5nIGNoZWNrcywgd29ya2Fyb3Vu ZCBmb3IgZXJyYXR1bSAzLjEyICJQQ0llIGNvbXBsZXRpb24gdGltZW91dCIgKi8KPiA+ID4gPiA+ ICsJcmVnID0gYWR2a19yZWFkbChwY2llLCBERUJVR19NVVhfQ1RSTF9SRUcpOwo+ID4gPiA+ID4g KwlyZWcgfD0gRElTX09SRF9DSEs7Cj4gPiA+ID4gPiArCWFkdmtfd3JpdGVsKHBjaWUsIHJlZywg REVCVUdfTVVYX0NUUkxfUkVHKTsKPiA+ID4gPiA+ICsKPiA+ID4gPiA+ICAJLyogU2V0IGxhbmUg WDEgKi8KPiA+ID4gPiA+ICAJcmVnID0gYWR2a19yZWFkbChwY2llLCBQQ0lFX0NPUkVfQ1RSTDBf UkVHKTsKPiA+ID4gPiA+ICAJcmVnICY9IH5MQU5FX0NOVF9NU0s7Cj4gPiA+ID4gPiBAQCAtMTU4 MSw2ICsxNTg4LDkgQEAgc3RhdGljIGlycXJldHVybl90IGFkdmtfcGNpZV9pcnFfaGFuZGxlcihp bnQgaXJxLCB2b2lkICphcmcpCj4gPiA+ID4gPiAgCXN0cnVjdCBhZHZrX3BjaWUgKnBjaWUgPSBh cmc7Cj4gPiA+ID4gPiAgCXUzMiBzdGF0dXM7Cj4gPiA+ID4gPiAgCj4gPiA+ID4gPiArCS8qIEZ1 bGwgbWVtb3J5IGJhcnJpZXIgKEFSTSBkc2Igc3kpLCB3b3JrYXJvdW5kIGZvciBlcnJhdHVtIDMu MTIgIlBDSWUgY29tcGxldGlvbiB0aW1lb3V0IiAqLwo+ID4gPiA+ID4gKwltYigpOwo+ID4gPiA+ ID4gKwo+ID4gPiA+ID4gIAlzdGF0dXMgPSBhZHZrX3JlYWRsKHBjaWUsIEhPU1RfQ1RSTF9JTlRf U1RBVFVTX1JFRyk7Cj4gPiA+ID4gPiAgCWlmICghKHN0YXR1cyAmIFBDSUVfSVJRX0NPUkVfSU5U KSkKPiA+ID4gPiA+ICAJCXJldHVybiBJUlFfTk9ORTsKPiA+ID4gPiA+IC0tCj4gPiA+ID4gPiAy LjIwLjEKPiA+ID4gPiA+IAo+ID4gPiAKPiA+ID4gX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX18KPiA+ID4gbGludXgtYXJtLWtlcm5lbCBtYWlsaW5nIGxpc3QK PiA+ID4gbGludXgtYXJtLWtlcm5lbEBsaXN0cy5pbmZyYWRlYWQub3JnCj4gPiA+IGh0dHBzOi8v dXJsZGVmZW5zZS5wcm9vZnBvaW50LmNvbS92Mi91cmw/dT1odHRwLTNBX19saXN0cy5pbmZyYWRl YWQuCj4gPiA+IG9yZ19tYWlsbWFuX2xpc3RpbmZvX2xpbnV4LTJEYXJtLTJEa2VybmVsJmQ9RHdJ RGFRJmM9bktqV2VjMmI2UjBtT3lQCj4gPiA+IGF6N3h0ZlEmcj1lVGVOVExFSzUtVHhYY3pqT2NL UGhBTklGdGxCOXBQNGxxOXFoZGxGcndRJm09Mk56a1Q5S0xPMjZrCj4gPiA+IGVmVU93Mm5JZVNl Um5KVlpMeEVpQlhxRW9SdkRRMHVld3c2bjRZYVhXZ0FOMXVDSlgyMG8mcz1uY3pBQ1NfMmpFUmJB Cj4gPiA+IC1jNEdmYXIwLUhUQTRQdHZaZEptc0J2OGpoVzhHMCZlPQo+IF9fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCj4gbGludXgtYXJtLWtlcm5lbCBtYWls aW5nIGxpc3QKPiBsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5vcmcKPiBodHRwOi8v bGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LWFybS1rZXJuZWwKCl9f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxpbnV4LWFybS1r ZXJuZWwgbWFpbGluZyBsaXN0CmxpbnV4LWFybS1rZXJuZWxAbGlzdHMuaW5mcmFkZWFkLm9yZwpo dHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LWFybS1rZXJu ZWwK