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 AED05C19F2A for ; Thu, 11 Aug 2022 12:57:47 +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:MIME-Version:References:In-Reply-To: Subject:Cc:To:From:Message-ID:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=Clcd3DxzVp6DcGUyfnr8xfl1AzVVFT4YgOSL0QH3ynw=; b=hc8BTmYXABQQIA 5fS+7xu56X8hR4kOVPZo/U/YeTceNiJLRmJ1fTnywSTskrKTR65q1nnQrHO3RRc1t+cF2vfjwKfCY 2q+XkbVHNpCJqknRcqNqxW/5DftqJsaM3TeSglQVZ902/nobMm27I6nkRxpmlDFP/zyYqJjvQRZAY BCC8ABwcfThyUjrvDcwyiNu8iAqCzWfT342G68974q0ukOInceGTGxv9iIlrvCeSBaqQ0r5M8+DDc 1iNZHhyLZ5dm0cAJOgJPbsUwxPHfunovy50fXGqfl/JON4Qh7fFZe1+zFq4/uoLlJ5R7QVaMrtJC+ EowBowhOYabB1P6pEW/g==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1oM7jg-00CMOA-Px; Thu, 11 Aug 2022 12:56:28 +0000 Received: from dfw.source.kernel.org ([139.178.84.217]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1oM7jd-00CMMt-Sh for linux-arm-kernel@lists.infradead.org; Thu, 11 Aug 2022 12:56:27 +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 dfw.source.kernel.org (Postfix) with ESMTPS id 4878861480; Thu, 11 Aug 2022 12:56:24 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id A5D9CC433C1; Thu, 11 Aug 2022 12:56:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1660222583; bh=BG0EIiB0G/2fnhVV42nQWkp6CJVQTQC8ZIJ8vLyaPYs=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=UZFsNSvUvlt4QQphm8bTQrlb6gUnTbmaewplUS9QqX7KcPa0EGGYIKFX5gFzwCOdt G+zzEeuqsjTr6MEkjg0aK0hAG+nEp6wmyT6NXwwBPjnOCmsjgQMG1L6B7MBL+lS2FF SJoS5mN7edBxOClxqjO2eL3maQOuG7rwofgGJG5PG1IJCHU8PFWIxvf5csDLtqjF6C SmZkq1dxGUIrTq0yJAhV27gLiQBAFheuryrt3oX7ZnqVlT7Ew/dS6EuDD931wPIAjQ B44EkWf4x+sCMKIZUSf6KuLmrai3mLCmjzqT9AmwnsDwZKsj1c8/dc77Kc2Qn/y8h3 EREDXpWk1fUwQ== Received: from sofa.misterjones.org ([185.219.108.64] helo=why.misterjones.org) by disco-boy.misterjones.org with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.95) (envelope-from ) id 1oM7jZ-002LKU-Kz; Thu, 11 Aug 2022 13:56:21 +0100 Date: Thu, 11 Aug 2022 13:56:21 +0100 Message-ID: <87lervuefe.wl-maz@kernel.org> From: Marc Zyngier To: Ricardo Koller Cc: Oliver Upton , linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, James Morse , Suzuki K Poulose , Alexandru Elisei , kernel-team@android.com Subject: Re: [PATCH 0/9] KVM: arm64: PMU: Fixing chained events, and PMUv3p5 support In-Reply-To: References: <20220805135813.2102034-1-maz@kernel.org> User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI-EPG/1.14.7 (Harue) FLIM-LB/1.14.9 (=?UTF-8?B?R29qxY0=?=) APEL-LB/10.8 EasyPG/1.0.0 Emacs/27.1 (x86_64-pc-linux-gnu) MULE/6.0 (HANACHIRUSATO) MIME-Version: 1.0 (generated by SEMI-EPG 1.14.7 - "Harue") X-SA-Exim-Connect-IP: 185.219.108.64 X-SA-Exim-Rcpt-To: ricarkol@google.com, oliver.upton@linux.dev, linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, kvm@vger.kernel.org, james.morse@arm.com, suzuki.poulose@arm.com, alexandru.elisei@arm.com, kernel-team@android.com X-SA-Exim-Mail-From: maz@kernel.org X-SA-Exim-Scanned: No (on disco-boy.misterjones.org); SAEximRunCond expanded to false X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220811_055626_025272_412DC324 X-CRM114-Status: GOOD ( 39.74 ) 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 T24gV2VkLCAxMCBBdWcgMjAyMiAyMjo1NTowMyArMDEwMCwKUmljYXJkbyBLb2xsZXIgPHJpY2Fy a29sQGdvb2dsZS5jb20+IHdyb3RlOgo+IAo+IE9uIFdlZCwgQXVnIDEwLCAyMDIyIGF0IDAyOjMz OjUzUE0gLTA1MDAsIE9saXZlciBVcHRvbiB3cm90ZToKPiA+IEhpIFJpY2FyZG8sCj4gPiAKPiA+ IE9uIFdlZCwgQXVnIDEwLCAyMDIyIGF0IDExOjQ2OjIyQU0gLTA3MDAsIFJpY2FyZG8gS29sbGVy IHdyb3RlOgo+ID4gPiBPbiBGcmksIEF1ZyAwNSwgMjAyMiBhdCAwMjo1ODowNFBNICswMTAwLCBN YXJjIFp5bmdpZXIgd3JvdGU6Cj4gPiA+ID4gUmljYXJkbyByZWNlbnRseSByZXBvcnRlZFsxXSB0 aGF0IG91ciBQTVUgZW11bGF0aW9uIHdhcyBidXN0ZWQgd2hlbiBpdAo+ID4gPiA+IGNvbWVzIHRv IGNoYWluZWQgZXZlbnRzLCBhcyB3ZSBjYW5ub3QgZXhwb3NlIHRoZSBvdmVyZmxvdyBvbiBhIDMy Yml0Cj4gPiA+ID4gYm91bmRhcnkgKHdoaWNoIHRoZSBhcmNoaXRlY3R1cmUgcmVxdWlyZXMpLgo+ ID4gPiA+IAo+ID4gPiA+IFRoaXMgc2VyaWVzIGFpbXMgYXQgZml4aW5nIHRoaXMgKGJ5IGRlbGV0 aW5nIGEgbG90IG9mIGNvZGUpLCBhbmQgYXMgYQo+ID4gPiA+IGJvbnVzIGFkZHMgc3VwcG9ydCBm b3IgUE1VdjNwNSwgYXMgdGhpcyByZXF1aXJlcyB1cyB0byBmaXggYSBmZXcgbW9yZQo+ID4gPiA+ IHRoaW5ncy4KPiA+ID4gPiAKPiA+ID4gPiBUZXN0ZWQgb24gQTUzIChQTVV2MykgYW5kIEZWUCAo UE1VdjNwNSkuCj4gPiA+ID4gCj4gPiA+ID4gWzFdIGh0dHBzOi8vbG9yZS5rZXJuZWwub3JnL3Iv MjAyMjA4MDUwMDQxMzkuOTkwNTMxLTEtcmljYXJrb2xAZ29vZ2xlLmNvbQo+ID4gPiA+IAo+ID4g PiA+IE1hcmMgWnluZ2llciAoOSk6Cj4gPiA+ID4gICBLVk06IGFybTY0OiBQTVU6IEFsaWduIGNo YWluZWQgY291bnRlciBpbXBsZW1lbnRhdGlvbiB3aXRoCj4gPiA+ID4gICAgIGFyY2hpdGVjdHVy ZSBwc2V1ZG9jb2RlCj4gPiA+ID4gICBLVk06IGFybTY0OiBQTVU6IERpc3Rpbmd1aXNoIGJldHdl ZW4gNjRiaXQgY291bnRlciBhbmQgNjRiaXQgb3ZlcmZsb3cKPiA+ID4gPiAgIEtWTTogYXJtNjQ6 IFBNVTogT25seSBuYXJyb3cgY291bnRlcnMgdGhhdCBhcmUgbm90IDY0Yml0IHdpZGUKPiA+ID4g PiAgIEtWTTogYXJtNjQ6IFBNVTogQWRkIGNvdW50ZXJfaW5kZXhfdG9fKnJlZygpIGhlbHBlcnMK PiA+ID4gPiAgIEtWTTogYXJtNjQ6IFBNVTogU2ltcGxpZnkgc2V0dGluZyBhIGNvdW50ZXIgdG8g YSBzcGVjaWZpYyB2YWx1ZQo+ID4gPiA+ICAgS1ZNOiBhcm02NDogUE1VOiBNb3ZlIHRoZSBJRF9B QTY0REZSMF9FTDEuUE1VdmVyIGxpbWl0IHRvIFZNIGNyZWF0aW9uCj4gPiA+ID4gICBLVk06IGFy bTY0OiBQTVU6IEFsZXZlbiBJRF9BQTY0REZSMF9FTDEuUE1VdmVyIHRvIGJlIHNldCBmcm9tIHVz ZXJzcGFjZQo+ID4gPiA+ICAgS1ZNOiBhcm02NDogUE1VOiBJbXBsZW1lbnQgUE1VdjNwNSBsb25n IGNvdW50ZXIgc3VwcG9ydAo+ID4gPiA+ICAgS1ZNOiBhcm02NDogUE1VOiBBbGV2ZW4gUE1VdjNw NSB0byBiZSBleHBvc2VkIHRvIHRoZSBndWVzdAo+ID4gPiA+IAo+ID4gPiA+ICBhcmNoL2FybTY0 L2luY2x1ZGUvYXNtL2t2bV9ob3N0LmggfCAgIDEgKwo+ID4gPiA+ICBhcmNoL2FybTY0L2t2bS9h cm0uYyAgICAgICAgICAgICAgfCAgIDYgKwo+ID4gPiA+ICBhcmNoL2FybTY0L2t2bS9wbXUtZW11 bC5jICAgICAgICAgfCAzNzIgKysrKysrKysrKy0tLS0tLS0tLS0tLS0tLS0tLS0tCj4gPiA+ID4g IGFyY2gvYXJtNjQva3ZtL3N5c19yZWdzLmMgICAgICAgICB8ICA2NSArKysrKy0KPiA+ID4gPiAg aW5jbHVkZS9rdm0vYXJtX3BtdS5oICAgICAgICAgICAgIHwgIDE2ICstCj4gPiA+ID4gIDUgZmls ZXMgY2hhbmdlZCwgMjA4IGluc2VydGlvbnMoKyksIDI1MiBkZWxldGlvbnMoLSkKPiA+ID4gPiAK PiA+ID4gPiAtLSAKPiA+ID4gPiAyLjM0LjEKPiA+ID4gPiAKPiA+ID4gCj4gPiA+IEhpIE1hcmMs Cj4gPiA+IAo+ID4gPiBUaGVyZSBpcyBvbmUgZXh0cmEgcG90ZW50aWFsIGlzc3VlIHdpdGggZXhw b3NpbmcgUE1VdjNwNS4gSSBzZWUgdGhpcwo+ID4gPiB3ZWlyZCBiZWhhdmlvciB3aGVuIGRvaW5n IHBhc3N0aHJvdWdoICgiYmFyZSBtZXRhbCIpIG9uIHRoZSBmYXN0LW1vZGVsCj4gPiA+IGNvbmZp Z3VyZWQgdG8gZW11bGF0ZSBQTVV2M3A1OiB0aGUgWzYzOjMyXSBoYWxmIG9mIHRoZSBjb3VudGVy cwo+ID4gPiBvdmVyZmxvd2luZyBhdCAzMi1iaXRzIGlzIHN0aWxsIGluY3JlbWVudGVkLgo+ID4g PiAKPiA+ID4gICBGYXN0IG1vZGVsIC0gQVJNdjguNToKPiA+ID4gICAgCj4gPiA+IAlBc3N1bWlu ZyB0aGUgaW5pdGlhbCBzdGF0ZSBpcyBldmVuPTB4RkZGRkZGRkYgYW5kIG9kZD0weDAsCj4gPiA+ IAlpbmNyZW1lbnRpbmcgdGhlIGV2ZW4gY291bnRlciBsZWFkcyB0bzoKPiA+ID4gCj4gPiA+IAkw eDAwMDAwMDAxXzAwMDAwMDAwCTB4MDAwMDAwMDBfMDAwMDAwMDEJCTB4MQo+ID4gPiAJZXZlbiBj b3VudGVyCQlvZGQgY291bnRlcgkJCVBNT1ZTRVQKPiA+ID4gCj4gPiA+IAlBc3N1bWluZyB0aGUg aW5pdGlhbCBzdGF0ZSBpcyBldmVuPTB4RkZGRkZGRkYgYW5kIG9kZD0weEZGRkZGRkZGLAo+ID4g PiAJaW5jcmVtZW50aW5nIHRoZSBldmVuIGNvdW50ZXIgbGVhZHMgdG86Cj4gPiA+IAo+ID4gPiAJ MHgwMDAwMDAwMV8wMDAwMDAwMAkweDAwMDAwMDAxXzAwMDAwMDAwCQkweDMKPiA+ID4gCWV2ZW4g Y291bnRlcgkJb2RkIGNvdW50ZXIJCQlQTU9WU0VUCj4gPiAKPiA+IFRoaXMgaXMgdG8gYmUgZXhw ZWN0ZWQsIGFjdHVhbGx5LiBQTVV2OHA1IGNvdW50ZXJzIGFyZSBhbHdheXMgNjQgYml0LAo+ID4g cmVnYXJkbGVzcyBvZiB0aGUgY29uZmlndXJlZCBvdmVyZmxvdy4KPiA+IAo+ID4gRERJIDA0ODdI IEQ4LjMgQmVoYXZpb3Igb24gb3ZlcmZsb3cKPiA+IAo+ID4gICBJZiBGRUFUX1BNVXYzcDUgaXMg aW1wbGVtZW50ZWQsIDY0LWJpdCBldmVudCBjb3VudGVycyBhcmUgaW1wbGVtZW50ZWQsCj4gPiAg IEhEQ1IuSFBNTiBpcyBub3QgMCwgYW5kIGVpdGhlciBuIGlzIGluIHRoZSByYW5nZSBbMCAuLiAo SERDUi5IUE1OLTEpXQo+ID4gICBvciBFTDIgaXMgbm90IGltcGxlbWVudGVkLCB0aGVuIGV2ZW50 IGNvdW50ZXIgb3ZlcmZsb3cgaXMgY29uZmlndXJlZAo+ID4gICBieSBQTUNSLkxQOgo+ID4gCj4g PiAgIOKAlCBXaGVuIFBNQ1IuTFAgaXMgc2V0IHRvIDAsIGlmIGluY3JlbWVudGluZyBQTUVWQ05U UjxuPiBjYXVzZXMgYW4gdW5zaWduZWQKPiA+ICAgICBvdmVyZmxvdyBvZiBiaXRzIFszMTowXSBv ZiB0aGUgZXZlbnQgY291bnRlciwgdGhlIFBFIHNldHMgUE1PVlNDTFJbbl0gdG8gMS4KPiA+ICAg 4oCUIFdoZW4gUE1DUi5MUCBpcyBzZXQgdG8gMSwgaWYgaW5jcmVtZW50aW5nIFBNRVZDTlRSPG4+ IGNhdXNlcyBhbiB1bnNpZ25lZAo+ID4gICAgIG92ZXJmbG93IG9mIGJpdHMgWzYzOjBdIG9mIHRo ZSBldmVudCBjb3VudGVyLCB0aGUgUEUgc2V0cyBQTU9WU0NMUltuXSB0byAxLgo+ID4gCj4gPiAg IFsuLi5dCj4gPiAKPiA+ICAgRm9yIGFsbCA2NC1iaXQgY291bnRlcnMsIGluY3JlbWVudGluZyB0 aGUgY291bnRlciBpcyB0aGUgc2FtZSB3aGV0aGVyIGFuCj4gPiAgIHVuc2lnbmVkIG92ZXJmbG93 IG9jY3VycyBhdCBbMzE6MF0gb3IgWzYzOjBdLiBJZiB0aGUgY291bnRlciBpbmNyZW1lbnRzCj4g PiAgIGZvciBhbiBldmVudCwgYml0cyBbNjM6MF0gYXJlIGFsd2F5cyBpbmNyZW1lbnRlZC4KPiA+ IAo+ID4gRG8geW91IHNlZSB0aGlzIHNhbWUgKGV4cGVjdGVkKSBmYWlsdXJlIHcvIE1hcmMncyBz ZXJpZXM/Cj4gCj4gSSBkb24ndCBrbm93LCBJJ20gaGl0dGluZyBhbm90aGVyIGJ1ZyBpdCBzZWVt cy4KPiAKPiBKdXN0IHJlYWxpemVkIHRoYXQgS1ZNIGRvZXMgbm90IG9mZmVyIFBNVXYzcDUgKHdp dGggdGhpcyBzZXJpZXMgYXBwbGllZCkKPiB3aGVuIHRoZSByZWFsIGhhcmR3YXJlIGlzIG9ubHkg QXJtdjguMiAodGhlIHNldHVwIEkgb3JpZ2luYWxseSB0cmllZCkuCj4gU28sIHRyaWVkIHRoZXNl IG90aGVyIHR3byBzZXR1cHMgb24gdGhlIGZhc3QgbW9kZWw6Cj4gCj4gaGFzX2FybV92OC01PTEK PiAKPiAJIyAuL2xrdm0tc3RhdGljIHJ1biAtLW5vZGVmYXVsdHMgLS1wbXUgcG11LmZsYXQgLXAg cG11LWNoYWluZWQtc3ctaW5jcgo+IAkjIGxrdm0gcnVuIC1rIHBtdS5mbGF0IC1tIDcwNCAtYyA4 IC0tbmFtZSBndWVzdC0xMzUKPiAKPiAJSU5GTzogUE1VIHZlcnNpb246IDB4Ngo+ICAgICAgICAg ICAgICAgICAgICAgICAgICAgIF5eXgo+ICAgICAgICAgICAgICAgICAgICAgICAgICAgIFBNVXYz IGZvciBBcm12OC41Cj4gCUlORk86IFBNVSBpbXBsZW1lbnRlci9JRCBjb2RlOiAweDQxKCJBIikv MAo+IAlJTkZPOiBJbXBsZW1lbnRzIDggZXZlbnQgY291bnRlcnMKPiAJRkFJTDogcG11OiBwbXUt Y2hhaW5lZC1zdy1pbmNyOiBvdmVyZmxvdyBhbmQgY2hhaW4gY291bnRlciBpbmNyZW1lbnRlZCBh ZnRlciAxMDAgU1dfSU5DUi9DSEFJTgo+IAlJTkZPOiBwbXU6IHBtdS1jaGFpbmVkLXN3LWluY3I6 IG92ZXJmbG93PTB4MCwgIzA9NDI5NDk2NzM4MCAjMT0wCj4gICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgIF5eXgo+ICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICBubyBvdmVyZmxvd3MKPiAJRkFJTDogcG11OiBwbXUt Y2hhaW5lZC1zdy1pbmNyOiBleHBlY3RlZCBvdmVyZmxvd3MgYW5kIHZhbHVlcyBhZnRlciAxMDAg U1dfSU5DUi9DSEFJTgo+IAlJTkZPOiBwbXU6IHBtdS1jaGFpbmVkLXN3LWluY3I6IG92ZXJmbG93 PTB4MCwgIzA9ODQgIzE9LTEKPiAJSU5GTzogcG11OiBwbXUtY2hhaW5lZC1zdy1pbmNyOiBvdmVy Zmxvdz0weDAsICMwPTQyOTQ5NjczODAgIzE9NDI5NDk2NzI5NQo+IAlTVU1NQVJZOiAyIHRlc3Rz LCAyIHVuZXhwZWN0ZWQgZmFpbHVyZXMKCkhtbS4gSSB0aGluayBJIHNlZSB3aGF0J3Mgd3Jvbmcu IEluIGt2bV9wbXVfY3JlYXRlX3BlcmZfZXZlbnQoKSwgd2UKaGF2ZSB0aGlzOgoKCWlmIChrdm1f cG11X2lkeF9pc182NGJpdCh2Y3B1LCBzZWxlY3RfaWR4KSkKCQlhdHRyLmNvbmZpZzEgfD0gMTsK Cgljb3VudGVyID0ga3ZtX3BtdV9nZXRfY291bnRlcl92YWx1ZSh2Y3B1LCBzZWxlY3RfaWR4KTsK CgkvKiBUaGUgaW5pdGlhbCBzYW1wbGUgcGVyaW9kIChvdmVyZmxvdyBjb3VudCkgb2YgYW4gZXZl bnQuICovCglpZiAoa3ZtX3BtdV9pZHhfaGFzXzY0Yml0X292ZXJmbG93KHZjcHUsIHNlbGVjdF9p ZHgpKQoJCWF0dHIuc2FtcGxlX3BlcmlvZCA9ICgtY291bnRlcikgJiBHRU5NQVNLKDYzLCAwKTsK CWVsc2UKCQlhdHRyLnNhbXBsZV9wZXJpb2QgPSAoLWNvdW50ZXIpICYgR0VOTUFTSygzMSwgMCk7 CgpidXQgdGhlIGluaXRpYWwgc2FtcGxpbmcgcGVyaW9kIHNob3VsZG4ndCBiZSBiYXNlZCBvbiB0 aGUgKmd1ZXN0Kgpjb3VudGVyIG92ZXJmbG93LiBJdCByZWFsbHkgaXMgYWJvdXQgdGhlIGdldHRp bmcgdG8gYW4gb3ZlcmZsb3cgb24gdGhlCipob3N0Kiwgc28gdGhlIGluaXRpYWwgY29kZSB3YXMg Y29ycmVjdCwgYW5kIG9ubHkgdGhlIHdpZHRoIG9mIHRoZQpjb3VudGVyIG1hdHRlcnMgaGVyZS4K Ci9tZSBnb2VzIGJhY2sgdG8gcnVubmluZyB0aGUgRlZQLi4uCgpUaGFua3MsCgoJTS4KCi0tIApX aXRob3V0IGRldmlhdGlvbiBmcm9tIHRoZSBub3JtLCBwcm9ncmVzcyBpcyBub3QgcG9zc2libGUu CgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpsaW51eC1h cm0ta2VybmVsIG1haWxpbmcgbGlzdApsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5v cmcKaHR0cDovL2xpc3RzLmluZnJhZGVhZC5vcmcvbWFpbG1hbi9saXN0aW5mby9saW51eC1hcm0t a2VybmVsCg==