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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id E890DC3DA66 for ; Thu, 24 Aug 2023 02:13:45 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239240AbjHXCNK (ORCPT ); Wed, 23 Aug 2023 22:13:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40704 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233104AbjHXCMi (ORCPT ); Wed, 23 Aug 2023 22:12:38 -0400 Received: from out30-132.freemail.mail.aliyun.com (out30-132.freemail.mail.aliyun.com [115.124.30.132]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 29B1FE75; Wed, 23 Aug 2023 19:12:33 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R201e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046050;MF=renyu.zj@linux.alibaba.com;NM=1;PH=DS;RN=21;SR=0;TI=SMTPD_---0VqS2I.A_1692843149; Received: from 30.221.146.144(mailfrom:renyu.zj@linux.alibaba.com fp:SMTPD_---0VqS2I.A_1692843149) by smtp.aliyun-inc.com; Thu, 24 Aug 2023 10:12:30 +0800 Message-ID: Date: Thu, 24 Aug 2023 10:12:28 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.14.0 Subject: Re: [PATCH v7 7/8] perf jevents: Add support for Arm CMN PMU aliasing To: Robin Murphy , John Garry , Ian Rogers Cc: Will Deacon , James Clark , Arnaldo Carvalho de Melo , Mark Rutland , Mike Leach , Leo Yan , Namhyung Kim , Peter Zijlstra , Ingo Molnar , Alexander Shishkin , Jiri Olsa , Adrian Hunter , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-perf-users@vger.kernel.org, linux-doc@vger.kernel.org, Zhuo Song , Shuai Xue References: <1692606977-92009-1-git-send-email-renyu.zj@linux.alibaba.com> <1692606977-92009-8-git-send-email-renyu.zj@linux.alibaba.com> <46a0917c-e288-7ef9-d72d-cdd53bb52a0a@arm.com> From: Jing Zhang In-Reply-To: <46a0917c-e288-7ef9-d72d-cdd53bb52a0a@arm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-doc@vger.kernel.org 在 2023/8/23 下午5:33, Robin Murphy 写道: > On 2023-08-21 09:36, Jing Zhang wrote: >> Currently just add aliases for part of Arm CMN PMU events which >> are general and compatible for any SoC and CMN-ANY. >> >> "Compat" value "434*;436*;43c*;43a*" means it is compatible with >> all CMN600/CMN650/CMN700/Ci700, which can be obtained from >> commit 7819e05a0dce ("perf/arm-cmn: Revamp model detection"). >> >> The arm-cmn PMU events got from: >> [0] https://developer.arm.com/documentation/100180/0302/?lang=en >> [1] https://developer.arm.com/documentation/101408/0100/?lang=en >> [2] https://developer.arm.com/documentation/102308/0302/?lang=en >> [3] https://developer.arm.com/documentation/101569/0300/?lang=en >> >> Signed-off-by: Jing Zhang >> Reviewed-by: John Garry >> --- >>   .../pmu-events/arch/arm64/arm/cmn/sys/cmn.json     | 266 +++++++++++++++++++++ >>   tools/perf/pmu-events/jevents.py                   |   1 + >>   2 files changed, 267 insertions(+) >>   create mode 100644 tools/perf/pmu-events/arch/arm64/arm/cmn/sys/cmn.json >> >> diff --git a/tools/perf/pmu-events/arch/arm64/arm/cmn/sys/cmn.json b/tools/perf/pmu-events/arch/arm64/arm/cmn/sys/cmn.json >> new file mode 100644 >> index 0000000..30435a3 >> --- /dev/null >> +++ b/tools/perf/pmu-events/arch/arm64/arm/cmn/sys/cmn.json >> @@ -0,0 +1,266 @@ >> +[ >> +    { >> +        "EventName": "hnf_cache_miss", >> +        "EventIdCode": "0x1", >> +        "NodeType": "0x5", > > Given my other comment, I also think there would be no harm in just having these as: >      >         "ConfigCode" : "0x10005" > > if you'd rather make life easier to begin with, then be able to come back and improve things later. IMO it doesn't affect the readability of the important values *all* that much, since it's not like they're tighly packed together in oddly-aligned bitfields. > Thanks a lot! that's a great suggestion. I hope to merge it in v6.6 first in the current way, and then I will improve it in CMN driver and perf tools later. Thanks, Jing > Thanks, > Robin. > >> +        "BriefDescription": "Counts total cache misses in first lookup result (high priority).", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_slc_sf_cache_access", >> +        "EventIdCode": "0x2", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of cache accesses in first access (high priority).", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_cache_fill", >> +        "EventIdCode": "0x3", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts total allocations in HN SLC (all cache line allocations to SLC).", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_pocq_retry", >> +        "EventIdCode": "0x4", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of retried requests.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_pocq_reqs_recvd", >> +        "EventIdCode": "0x5", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of requests that HN receives.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_sf_hit", >> +        "EventIdCode": "0x6", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of SF hits.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_sf_evictions", >> +        "EventIdCode": "0x7", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of SF eviction cache invalidations initiated.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_dir_snoops_sent", >> +        "EventIdCode": "0x8", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of directed snoops sent (not including SF back invalidation).", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_brd_snoops_sent", >> +        "EventIdCode": "0x9", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of multicast snoops sent (not including SF back invalidation).", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_slc_eviction", >> +        "EventIdCode": "0xa", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of SLC evictions (dirty only).", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_slc_fill_invalid_way", >> +        "EventIdCode": "0xb", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of SLC fills to an invalid way.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_mc_retries", >> +        "EventIdCode": "0xc", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of retried transactions by the MC.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_mc_reqs", >> +        "EventIdCode": "0xd", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of requests that are sent to MC.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hnf_qos_hh_retry", >> +        "EventIdCode": "0xe", >> +        "NodeType": "0x5", >> +        "BriefDescription": "Counts number of times a HighHigh priority request is protocolretried at the HN‑F.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_s0_rdata_beats", >> +        "EventIdCode": "0x1", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of RData beats (RVALID and RREADY) dispatched on port 0. This event measures the read bandwidth, including CMO responses.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_s1_rdata_beats", >> +        "EventIdCode": "0x2", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of RData beats (RVALID and RREADY) dispatched on port 1. This event measures the read bandwidth, including CMO responses.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_s2_rdata_beats", >> +        "EventIdCode": "0x3", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of RData beats (RVALID and RREADY) dispatched on port 2. This event measures the read bandwidth, including CMO responses.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_rxdat_flits", >> +        "EventIdCode": "0x4", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of RXDAT flits received. This event measures the true read data bandwidth, excluding CMOs.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_txdat_flits", >> +        "EventIdCode": "0x5", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of TXDAT flits dispatched. This event measures the write bandwidth.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_txreq_flits_total", >> +        "EventIdCode": "0x6", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of TXREQ flits dispatched. This event measures the total request bandwidth.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "rnid_txreq_flits_retried", >> +        "EventIdCode": "0x7", >> +        "NodeType": "0xa", >> +        "BriefDescription": "Number of retried TXREQ flits dispatched. This event measures the retry rate.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "sbsx_txrsp_retryack", >> +        "EventIdCode": "0x4", >> +        "NodeType": "0x7", >> +        "BriefDescription": "Number of RXREQ flits dispatched. This event is a measure of the retry rate.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "sbsx_txdat_flitv", >> +        "EventIdCode": "0x5", >> +        "NodeType": "0x7", >> +        "BriefDescription": "Number of TXDAT flits dispatched from XP to SBSX. This event is a measure of the write bandwidth.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "sbsx_arvalid_no_arready", >> +        "EventIdCode": "0x21", >> +        "NodeType": "0x7", >> +        "BriefDescription": "Number of cycles the SBSX bridge is stalled because of backpressure on AR channel.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "sbsx_awvalid_no_awready", >> +        "EventIdCode": "0x22", >> +        "NodeType": "0x7", >> +        "BriefDescription": "Number of cycles the SBSX bridge is stalled because of backpressure on AW channel.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "sbsx_wvalid_no_wready", >> +        "EventIdCode": "0x23", >> +        "NodeType": "0x7", >> +        "BriefDescription": "Number of cycles the SBSX bridge is stalled because of backpressure on W channel.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_txrsp_retryack", >> +        "EventIdCode": "0x2a", >> +        "NodeType": "0x4", >> +        "BriefDescription": "Number of RXREQ flits dispatched. This event is a measure of the retry rate.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_arvalid_no_arready", >> +        "EventIdCode": "0x2b", >> +        "NodeType": "0x4", >> +        "BriefDescription": "Number of cycles the HN-I bridge is stalled because of backpressure on AR channel.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_arready_no_arvalid", >> +        "EventIdCode": "0x2c", >> +        "NodeType": "0x4", >> +        "BriefDescription": "Number of cycles the AR channel is waiting for new requests from HN-I bridge.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_awvalid_no_awready", >> +        "EventIdCode": "0x2d", >> +        "NodeType": "0x4", >> +        "BriefDescription": "Number of cycles the HN-I bridge is stalled because of backpressure on AW channel.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_awready_no_awvalid", >> +        "EventIdCode": "0x2e", >> +        "NodeType": "0x4", >> +        "BriefDescription": "Number of cycles the AW channel is waiting for new requests from HN-I bridge.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_wvalid_no_wready", >> +        "EventIdCode": "0x2f", >> +        "NodeType": "0x4", >> +        "BriefDescription": "Number of cycles the HN-I bridge is stalled because of backpressure on W channel.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    }, >> +    { >> +        "EventName": "hni_txdat_stall", >> +        "EventIdCode": "0x30", >> +        "NodeType": "0x4", >> +        "BriefDescription": "TXDAT valid but no link credit available.", >> +        "Unit": "arm_cmn", >> +        "Compat": "434*;436*;43c*;43a*" >> +    } >> +] >> diff --git a/tools/perf/pmu-events/jevents.py b/tools/perf/pmu-events/jevents.py >> index 369c8bf..935bd4b 100755 >> --- a/tools/perf/pmu-events/jevents.py >> +++ b/tools/perf/pmu-events/jevents.py >> @@ -272,6 +272,7 @@ class JsonEvent: >>             'DFPMC': 'amd_df', >>             'cpu_core': 'cpu_core', >>             'cpu_atom': 'cpu_atom', >> +          'arm_cmn': 'arm_cmn', >>         } >>         return table[unit] if unit in table else f'uncore_{unit.lower()}' >>   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 EF672C27C40 for ; Thu, 24 Aug 2023 02:13:19 +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:From:References:Cc:To: Subject:MIME-Version:Date:Message-ID:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=DfGqwLqEBgpdvnpngGUeOyosoWyx/cPG9gE79ejETNk=; b=Y4Ei+Eqw2hfpT4 CI2bw6ZjfiCCZJDNBChaDPEV2erQURzy0yujQtnwD/AcGwP62WPmLk1LEccCXkPFyd9R/4YtuXRlt HhOIKV3Lwsf3Unx6QUiF5W16U5shLxTYnbVExfOuq23yqwsMFo0vpFaNzPg/yNpNU3YZ9vs6g954o dG0M9IaibWwBF2bP+nMUcOMR85cPSJx4U7ZxgiXS57ypTWxUzyX0ukBdGfgZNMcdlbcyn1TvRDuFq hCzGbqJ1aaudbbCkMiKLNBgxXALRUVT5gBMAFqgZVRPPPdX81iiYXfGLuiHQaPv7deM2FqT451gKv KggEgklXcZlSmbrlf9LQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1qYzq0-001wXB-05; Thu, 24 Aug 2023 02:12:44 +0000 Received: from out30-124.freemail.mail.aliyun.com ([115.124.30.124]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1qYzpv-001wVk-1r for linux-arm-kernel@lists.infradead.org; Thu, 24 Aug 2023 02:12:42 +0000 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R201e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046050;MF=renyu.zj@linux.alibaba.com;NM=1;PH=DS;RN=21;SR=0;TI=SMTPD_---0VqS2I.A_1692843149; Received: from 30.221.146.144(mailfrom:renyu.zj@linux.alibaba.com fp:SMTPD_---0VqS2I.A_1692843149) by smtp.aliyun-inc.com; Thu, 24 Aug 2023 10:12:30 +0800 Message-ID: Date: Thu, 24 Aug 2023 10:12:28 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.14.0 Subject: Re: [PATCH v7 7/8] perf jevents: Add support for Arm CMN PMU aliasing To: Robin Murphy , John Garry , Ian Rogers Cc: Will Deacon , James Clark , Arnaldo Carvalho de Melo , Mark Rutland , Mike Leach , Leo Yan , Namhyung Kim , Peter Zijlstra , Ingo Molnar , Alexander Shishkin , Jiri Olsa , Adrian Hunter , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-perf-users@vger.kernel.org, linux-doc@vger.kernel.org, Zhuo Song , Shuai Xue References: <1692606977-92009-1-git-send-email-renyu.zj@linux.alibaba.com> <1692606977-92009-8-git-send-email-renyu.zj@linux.alibaba.com> <46a0917c-e288-7ef9-d72d-cdd53bb52a0a@arm.com> From: Jing Zhang In-Reply-To: <46a0917c-e288-7ef9-d72d-cdd53bb52a0a@arm.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230823_191239_955111_9C5ACC81 X-CRM114-Status: GOOD ( 19.15 ) 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 CgrlnKggMjAyMy84LzIzIOS4i+WNiDU6MzMsIFJvYmluIE11cnBoeSDlhpnpgZM6Cj4gT24gMjAy My0wOC0yMSAwOTozNiwgSmluZyBaaGFuZyB3cm90ZToKPj4gQ3VycmVudGx5IGp1c3QgYWRkIGFs aWFzZXMgZm9yIHBhcnQgb2YgQXJtIENNTiBQTVUgZXZlbnRzIHdoaWNoCj4+IGFyZSBnZW5lcmFs IGFuZCBjb21wYXRpYmxlIGZvciBhbnkgU29DIGFuZCBDTU4tQU5ZLgo+Pgo+PiAiQ29tcGF0IiB2 YWx1ZSAiNDM0Kjs0MzYqOzQzYyo7NDNhKiIgbWVhbnMgaXQgaXMgY29tcGF0aWJsZSB3aXRoCj4+ IGFsbCBDTU42MDAvQ01ONjUwL0NNTjcwMC9DaTcwMCwgd2hpY2ggY2FuIGJlIG9idGFpbmVkIGZy b20KPj4gY29tbWl0IDc4MTllMDVhMGRjZSAoInBlcmYvYXJtLWNtbjogUmV2YW1wIG1vZGVsIGRl dGVjdGlvbiIpLgo+Pgo+PiBUaGUgYXJtLWNtbiBQTVUgZXZlbnRzIGdvdCBmcm9tOgo+PiBbMF0g aHR0cHM6Ly9kZXZlbG9wZXIuYXJtLmNvbS9kb2N1bWVudGF0aW9uLzEwMDE4MC8wMzAyLz9sYW5n PWVuCj4+IFsxXSBodHRwczovL2RldmVsb3Blci5hcm0uY29tL2RvY3VtZW50YXRpb24vMTAxNDA4 LzAxMDAvP2xhbmc9ZW4KPj4gWzJdIGh0dHBzOi8vZGV2ZWxvcGVyLmFybS5jb20vZG9jdW1lbnRh dGlvbi8xMDIzMDgvMDMwMi8/bGFuZz1lbgo+PiBbM10gaHR0cHM6Ly9kZXZlbG9wZXIuYXJtLmNv bS9kb2N1bWVudGF0aW9uLzEwMTU2OS8wMzAwLz9sYW5nPWVuCj4+Cj4+IFNpZ25lZC1vZmYtYnk6 IEppbmcgWmhhbmcgPHJlbnl1LnpqQGxpbnV4LmFsaWJhYmEuY29tPgo+PiBSZXZpZXdlZC1ieTog Sm9obiBHYXJyeSA8am9obi5nLmdhcnJ5QG9yYWNsZS5jb20+Cj4+IC0tLQo+PiDCoCAuLi4vcG11 LWV2ZW50cy9hcmNoL2FybTY0L2FybS9jbW4vc3lzL2Ntbi5qc29uwqDCoMKgwqAgfCAyNjYgKysr KysrKysrKysrKysrKysrKysrCj4+IMKgIHRvb2xzL3BlcmYvcG11LWV2ZW50cy9qZXZlbnRzLnB5 wqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIHzCoMKgIDEgKwo+PiDCoCAyIGZp bGVzIGNoYW5nZWQsIDI2NyBpbnNlcnRpb25zKCspCj4+IMKgIGNyZWF0ZSBtb2RlIDEwMDY0NCB0 b29scy9wZXJmL3BtdS1ldmVudHMvYXJjaC9hcm02NC9hcm0vY21uL3N5cy9jbW4uanNvbgo+Pgo+ PiBkaWZmIC0tZ2l0IGEvdG9vbHMvcGVyZi9wbXUtZXZlbnRzL2FyY2gvYXJtNjQvYXJtL2Ntbi9z eXMvY21uLmpzb24gYi90b29scy9wZXJmL3BtdS1ldmVudHMvYXJjaC9hcm02NC9hcm0vY21uL3N5 cy9jbW4uanNvbgo+PiBuZXcgZmlsZSBtb2RlIDEwMDY0NAo+PiBpbmRleCAwMDAwMDAwLi4zMDQz NWEzCj4+IC0tLSAvZGV2L251bGwKPj4gKysrIGIvdG9vbHMvcGVyZi9wbXUtZXZlbnRzL2FyY2gv YXJtNjQvYXJtL2Ntbi9zeXMvY21uLmpzb24KPj4gQEAgLTAsMCArMSwyNjYgQEAKPj4gK1sKPj4g K8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuZl9jYWNoZV9taXNz IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudElkQ29kZSI6ICIweDEiLAo+PiArwqDCoMKgwqDC oMKgwqAgIk5vZGVUeXBlIjogIjB4NSIsCj4gCj4gR2l2ZW4gbXkgb3RoZXIgY29tbWVudCwgSSBh bHNvIHRoaW5rIHRoZXJlIHdvdWxkIGJlIG5vIGhhcm0gaW4ganVzdCBoYXZpbmcgdGhlc2UgYXM6 Cj4gwqDCoMKgwqAKPiDCoMKgwqDCoMKgwqDCoCAiQ29uZmlnQ29kZSIgOiAiMHgxMDAwNSIKPiAK PiBpZiB5b3UnZCByYXRoZXIgbWFrZSBsaWZlIGVhc2llciB0byBiZWdpbiB3aXRoLCB0aGVuIGJl IGFibGUgdG8gY29tZSBiYWNrIGFuZCBpbXByb3ZlIHRoaW5ncyBsYXRlci4gSU1PIGl0IGRvZXNu J3QgYWZmZWN0IHRoZSByZWFkYWJpbGl0eSBvZiB0aGUgaW1wb3J0YW50IHZhbHVlcyAqYWxsKiB0 aGF0IG11Y2gsIHNpbmNlIGl0J3Mgbm90IGxpa2UgdGhleSdyZSB0aWdobHkgcGFja2VkIHRvZ2V0 aGVyIGluIG9kZGx5LWFsaWduZWQgYml0ZmllbGRzLgo+IAoKVGhhbmtzIGEgbG90ISB0aGF0J3Mg YSBncmVhdCBzdWdnZXN0aW9uLiAgSSBob3BlIHRvIG1lcmdlIGl0IGluIHY2LjYgZmlyc3QgaW4g dGhlIGN1cnJlbnQgd2F5LAphbmQgdGhlbiBJIHdpbGwgaW1wcm92ZSBpdCBpbiBDTU4gZHJpdmVy IGFuZCBwZXJmIHRvb2xzIGxhdGVyLgoKVGhhbmtzLApKaW5nCgoKPiBUaGFua3MsCj4gUm9iaW4u Cj4gCj4+ICvCoMKgwqDCoMKgwqDCoCAiQnJpZWZEZXNjcmlwdGlvbiI6ICJDb3VudHMgdG90YWwg Y2FjaGUgbWlzc2VzIGluIGZpcnN0IGxvb2t1cCByZXN1bHQgKGhpZ2ggcHJpb3JpdHkpLiIsCj4+ ICvCoMKgwqDCoMKgwqDCoCAiVW5pdCI6ICJhcm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJD b21wYXQiOiAiNDM0Kjs0MzYqOzQzYyo7NDNhKiIKPj4gK8KgwqDCoCB9LAo+PiArwqDCoMKgIHsK Pj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudE5hbWUiOiAiaG5mX3NsY19zZl9jYWNoZV9hY2Nlc3Mi LAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MiIsCj4+ICvCoMKgwqDCoMKg wqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0 aW9uIjogIkNvdW50cyBudW1iZXIgb2YgY2FjaGUgYWNjZXNzZXMgaW4gZmlyc3QgYWNjZXNzICho aWdoIHByaW9yaXR5KS4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKg wqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuZl9j YWNoZV9maWxsIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudElkQ29kZSI6ICIweDMiLAo+PiAr wqDCoMKgwqDCoMKgwqAgIk5vZGVUeXBlIjogIjB4NSIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQnJp ZWZEZXNjcmlwdGlvbiI6ICJDb3VudHMgdG90YWwgYWxsb2NhdGlvbnMgaW4gSE4gU0xDIChhbGwg Y2FjaGUgbGluZSBhbGxvY2F0aW9ucyB0byBTTEMpLiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiVW5p dCI6ICJhcm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21wYXQiOiAiNDM0Kjs0MzYqOzQz Yyo7NDNhKiIKPj4gK8KgwqDCoCB9LAo+PiArwqDCoMKgIHsKPj4gK8KgwqDCoMKgwqDCoMKgICJF dmVudE5hbWUiOiAiaG5mX3BvY3FfcmV0cnkiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRD b2RlIjogIjB4NCIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8Kg wqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgcmV0cmll ZCByZXF1ZXN0cy4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvC oMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAg fSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuZl9wb2Nx X3JlcXNfcmVjdmQiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4NSIsCj4+ ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJC cmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgcmVxdWVzdHMgdGhhdCBITiByZWNl aXZlcy4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDC oMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4g K8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuZl9zZl9oaXQiLAo+ PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4NiIsCj4+ICvCoMKgwqDCoMKgwqDC oCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9u IjogIkNvdW50cyBudW1iZXIgb2YgU0YgaGl0cy4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQi OiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2Mq OzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZl bnROYW1lIjogImhuZl9zZl9ldmljdGlvbnMiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRD b2RlIjogIjB4NyIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8Kg wqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgU0YgZXZp Y3Rpb24gY2FjaGUgaW52YWxpZGF0aW9ucyBpbml0aWF0ZWQuIiwKPj4gK8KgwqDCoMKgwqDCoMKg ICJVbml0IjogImFybV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkNvbXBhdCI6ICI0MzQqOzQz Nio7NDNjKjs0M2EqIgo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAgewo+PiArwqDCoMKgwqDCoMKg wqAgIkV2ZW50TmFtZSI6ICJobmZfZGlyX3Nub29wc19zZW50IiwKPj4gK8KgwqDCoMKgwqDCoMKg ICJFdmVudElkQ29kZSI6ICIweDgiLAo+PiArwqDCoMKgwqDCoMKgwqAgIk5vZGVUeXBlIjogIjB4 NSIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQnJpZWZEZXNjcmlwdGlvbiI6ICJDb3VudHMgbnVtYmVy IG9mIGRpcmVjdGVkIHNub29wcyBzZW50IChub3QgaW5jbHVkaW5nIFNGIGJhY2sgaW52YWxpZGF0 aW9uKS4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDC oMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4g K8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuZl9icmRfc25vb3Bz X3NlbnQiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4OSIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRl c2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgbXVsdGljYXN0IHNub29wcyBzZW50IChub3Qg aW5jbHVkaW5nIFNGIGJhY2sgaW52YWxpZGF0aW9uKS4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVu aXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0 M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAi RXZlbnROYW1lIjogImhuZl9zbGNfZXZpY3Rpb24iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50 SWRDb2RlIjogIjB4YSIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4g K8KgwqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgU0xD IGV2aWN0aW9ucyAoZGlydHkgb25seSkuIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJVbml0IjogImFy bV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkNvbXBhdCI6ICI0MzQqOzQzNio7NDNjKjs0M2Eq Igo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAgewo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50TmFt ZSI6ICJobmZfc2xjX2ZpbGxfaW52YWxpZF93YXkiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50 SWRDb2RlIjogIjB4YiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4g K8KgwqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgU0xD IGZpbGxzIHRvIGFuIGludmFsaWQgd2F5LiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiVW5pdCI6ICJh cm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21wYXQiOiAiNDM0Kjs0MzYqOzQzYyo7NDNh KiIKPj4gK8KgwqDCoCB9LAo+PiArwqDCoMKgIHsKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudE5h bWUiOiAiaG5mX21jX3JldHJpZXMiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjog IjB4YyIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKg wqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgcmV0cmllZCB0cmFu c2FjdGlvbnMgYnkgdGhlIE1DLiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiVW5pdCI6ICJhcm1fY21u IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21wYXQiOiAiNDM0Kjs0MzYqOzQzYyo7NDNhKiIKPj4g K8KgwqDCoCB9LAo+PiArwqDCoMKgIHsKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudE5hbWUiOiAi aG5mX21jX3JlcXMiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4ZCIsCj4+ ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJC cmllZkRlc2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgcmVxdWVzdHMgdGhhdCBhcmUgc2Vu dCB0byBNQy4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwK Pj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuZl9xb3NfaGhf cmV0cnkiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4ZSIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRl c2NyaXB0aW9uIjogIkNvdW50cyBudW1iZXIgb2YgdGltZXMgYSBIaWdoSGlnaCBwcmlvcml0eSBy ZXF1ZXN0IGlzIHByb3RvY29scmV0cmllZCBhdCB0aGUgSE7igJFGLiIsCj4+ICvCoMKgwqDCoMKg wqDCoCAiVW5pdCI6ICJhcm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21wYXQiOiAiNDM0 Kjs0MzYqOzQzYyo7NDNhKiIKPj4gK8KgwqDCoCB9LAo+PiArwqDCoMKgIHsKPj4gK8KgwqDCoMKg wqDCoMKgICJFdmVudE5hbWUiOiAicm5pZF9zMF9yZGF0YV9iZWF0cyIsCj4+ICvCoMKgwqDCoMKg wqDCoCAiRXZlbnRJZENvZGUiOiAiMHgxIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2RlVHlwZSI6 ICIweGEiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVtYmVyIG9m IFJEYXRhIGJlYXRzIChSVkFMSUQgYW5kIFJSRUFEWSkgZGlzcGF0Y2hlZCBvbiBwb3J0IDAuIFRo aXMgZXZlbnQgbWVhc3VyZXMgdGhlIHJlYWQgYmFuZHdpZHRoLCBpbmNsdWRpbmcgQ01PIHJlc3Bv bnNlcy4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDC oMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4g K8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogInJuaWRfczFfcmRhdGFf YmVhdHMiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MiIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHhhIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRl c2NyaXB0aW9uIjogIk51bWJlciBvZiBSRGF0YSBiZWF0cyAoUlZBTElEIGFuZCBSUkVBRFkpIGRp c3BhdGNoZWQgb24gcG9ydCAxLiBUaGlzIGV2ZW50IG1lYXN1cmVzIHRoZSByZWFkIGJhbmR3aWR0 aCwgaW5jbHVkaW5nIENNTyByZXNwb25zZXMuIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJVbml0Ijog ImFybV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkNvbXBhdCI6ICI0MzQqOzQzNio7NDNjKjs0 M2EqIgo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAgewo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50 TmFtZSI6ICJybmlkX3MyX3JkYXRhX2JlYXRzIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudElk Q29kZSI6ICIweDMiLAo+PiArwqDCoMKgwqDCoMKgwqAgIk5vZGVUeXBlIjogIjB4YSIsCj4+ICvC oMKgwqDCoMKgwqDCoCAiQnJpZWZEZXNjcmlwdGlvbiI6ICJOdW1iZXIgb2YgUkRhdGEgYmVhdHMg KFJWQUxJRCBhbmQgUlJFQURZKSBkaXNwYXRjaGVkIG9uIHBvcnQgMi4gVGhpcyBldmVudCBtZWFz dXJlcyB0aGUgcmVhZCBiYW5kd2lkdGgsIGluY2x1ZGluZyBDTU8gcmVzcG9uc2VzLiIsCj4+ICvC oMKgwqDCoMKgwqDCoCAiVW5pdCI6ICJhcm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21w YXQiOiAiNDM0Kjs0MzYqOzQzYyo7NDNhKiIKPj4gK8KgwqDCoCB9LAo+PiArwqDCoMKgIHsKPj4g K8KgwqDCoMKgwqDCoMKgICJFdmVudE5hbWUiOiAicm5pZF9yeGRhdF9mbGl0cyIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiRXZlbnRJZENvZGUiOiAiMHg0IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2Rl VHlwZSI6ICIweGEiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVt YmVyIG9mIFJYREFUIGZsaXRzIHJlY2VpdmVkLiBUaGlzIGV2ZW50IG1lYXN1cmVzIHRoZSB0cnVl IHJlYWQgZGF0YSBiYW5kd2lkdGgsIGV4Y2x1ZGluZyBDTU9zLiIsCj4+ICvCoMKgwqDCoMKgwqDC oCAiVW5pdCI6ICJhcm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21wYXQiOiAiNDM0Kjs0 MzYqOzQzYyo7NDNhKiIKPj4gK8KgwqDCoCB9LAo+PiArwqDCoMKgIHsKPj4gK8KgwqDCoMKgwqDC oMKgICJFdmVudE5hbWUiOiAicm5pZF90eGRhdF9mbGl0cyIsCj4+ICvCoMKgwqDCoMKgwqDCoCAi RXZlbnRJZENvZGUiOiAiMHg1IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2RlVHlwZSI6ICIweGEi LAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVtYmVyIG9mIFRYREFU IGZsaXRzIGRpc3BhdGNoZWQuIFRoaXMgZXZlbnQgbWVhc3VyZXMgdGhlIHdyaXRlIGJhbmR3aWR0 aC4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKg wqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8Kg wqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogInJuaWRfdHhyZXFfZmxpdHNf dG90YWwiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4NiIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHhhIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRl c2NyaXB0aW9uIjogIk51bWJlciBvZiBUWFJFUSBmbGl0cyBkaXNwYXRjaGVkLiBUaGlzIGV2ZW50 IG1lYXN1cmVzIHRoZSB0b3RhbCByZXF1ZXN0IGJhbmR3aWR0aC4iLAo+PiArwqDCoMKgwqDCoMKg wqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7 NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKg wqDCoCAiRXZlbnROYW1lIjogInJuaWRfdHhyZXFfZmxpdHNfcmV0cmllZCIsCj4+ICvCoMKgwqDC oMKgwqDCoCAiRXZlbnRJZENvZGUiOiAiMHg3IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2RlVHlw ZSI6ICIweGEiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVtYmVy IG9mIHJldHJpZWQgVFhSRVEgZmxpdHMgZGlzcGF0Y2hlZC4gVGhpcyBldmVudCBtZWFzdXJlcyB0 aGUgcmV0cnkgcmF0ZS4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKg wqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogInNic3hf dHhyc3BfcmV0cnlhY2siLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4NCIs Cj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg3IiwKPj4gK8KgwqDCoMKgwqDCoMKg ICJCcmllZkRlc2NyaXB0aW9uIjogIk51bWJlciBvZiBSWFJFUSBmbGl0cyBkaXNwYXRjaGVkLiBU aGlzIGV2ZW50IGlzIGEgbWVhc3VyZSBvZiB0aGUgcmV0cnkgcmF0ZS4iLAo+PiArwqDCoMKgwqDC oMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQz NCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDC oMKgwqDCoCAiRXZlbnROYW1lIjogInNic3hfdHhkYXRfZmxpdHYiLAo+PiArwqDCoMKgwqDCoMKg wqAgIkV2ZW50SWRDb2RlIjogIjB4NSIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAi MHg3IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIk51bWJlciBvZiBU WERBVCBmbGl0cyBkaXNwYXRjaGVkIGZyb20gWFAgdG8gU0JTWC4gVGhpcyBldmVudCBpcyBhIG1l YXN1cmUgb2YgdGhlIHdyaXRlIGJhbmR3aWR0aC4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQi OiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2Mq OzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZl bnROYW1lIjogInNic3hfYXJ2YWxpZF9ub19hcnJlYWR5IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJF dmVudElkQ29kZSI6ICIweDIxIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2RlVHlwZSI6ICIweDci LAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVtYmVyIG9mIGN5Y2xl cyB0aGUgU0JTWCBicmlkZ2UgaXMgc3RhbGxlZCBiZWNhdXNlIG9mIGJhY2twcmVzc3VyZSBvbiBB UiBjaGFubmVsLiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiVW5pdCI6ICJhcm1fY21uIiwKPj4gK8Kg wqDCoMKgwqDCoMKgICJDb21wYXQiOiAiNDM0Kjs0MzYqOzQzYyo7NDNhKiIKPj4gK8KgwqDCoCB9 LAo+PiArwqDCoMKgIHsKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudE5hbWUiOiAic2JzeF9hd3Zh bGlkX25vX2F3cmVhZHkiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MjIi LAo+PiArwqDCoMKgwqDCoMKgwqAgIk5vZGVUeXBlIjogIjB4NyIsCj4+ICvCoMKgwqDCoMKgwqDC oCAiQnJpZWZEZXNjcmlwdGlvbiI6ICJOdW1iZXIgb2YgY3ljbGVzIHRoZSBTQlNYIGJyaWRnZSBp cyBzdGFsbGVkIGJlY2F1c2Ugb2YgYmFja3ByZXNzdXJlIG9uIEFXIGNoYW5uZWwuIiwKPj4gK8Kg wqDCoMKgwqDCoMKgICJVbml0IjogImFybV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkNvbXBh dCI6ICI0MzQqOzQzNio7NDNjKjs0M2EqIgo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAgewo+PiAr wqDCoMKgwqDCoMKgwqAgIkV2ZW50TmFtZSI6ICJzYnN4X3d2YWxpZF9ub193cmVhZHkiLAo+PiAr wqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MjMiLAo+PiArwqDCoMKgwqDCoMKgwqAg Ik5vZGVUeXBlIjogIjB4NyIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQnJpZWZEZXNjcmlwdGlvbiI6 ICJOdW1iZXIgb2YgY3ljbGVzIHRoZSBTQlNYIGJyaWRnZSBpcyBzdGFsbGVkIGJlY2F1c2Ugb2Yg YmFja3ByZXNzdXJlIG9uIFcgY2hhbm5lbC4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAi YXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQz YSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnRO YW1lIjogImhuaV90eHJzcF9yZXRyeWFjayIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnRJZENv ZGUiOiAiMHgyYSIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiTm9kZVR5cGUiOiAiMHg0IiwKPj4gK8Kg wqDCoMKgwqDCoMKgICJCcmllZkRlc2NyaXB0aW9uIjogIk51bWJlciBvZiBSWFJFUSBmbGl0cyBk aXNwYXRjaGVkLiBUaGlzIGV2ZW50IGlzIGEgbWVhc3VyZSBvZiB0aGUgcmV0cnkgcmF0ZS4iLAo+ PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKgwqDCoMKgwqDCoCAi Q29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7 Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuaV9hcnZhbGlkX25vX2FycmVhZHki LAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MmIiLAo+PiArwqDCoMKgwqDC oMKgwqAgIk5vZGVUeXBlIjogIjB4NCIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQnJpZWZEZXNjcmlw dGlvbiI6ICJOdW1iZXIgb2YgY3ljbGVzIHRoZSBITi1JIGJyaWRnZSBpcyBzdGFsbGVkIGJlY2F1 c2Ugb2YgYmFja3ByZXNzdXJlIG9uIEFSIGNoYW5uZWwuIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJV bml0IjogImFybV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkNvbXBhdCI6ICI0MzQqOzQzNio7 NDNjKjs0M2EqIgo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAgewo+PiArwqDCoMKgwqDCoMKgwqAg IkV2ZW50TmFtZSI6ICJobmlfYXJyZWFkeV9ub19hcnZhbGlkIiwKPj4gK8KgwqDCoMKgwqDCoMKg ICJFdmVudElkQ29kZSI6ICIweDJjIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2RlVHlwZSI6ICIw eDQiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVtYmVyIG9mIGN5 Y2xlcyB0aGUgQVIgY2hhbm5lbCBpcyB3YWl0aW5nIGZvciBuZXcgcmVxdWVzdHMgZnJvbSBITi1J IGJyaWRnZS4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2NtbiIsCj4+ICvCoMKg wqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ICvCoMKgwqAgfSwK Pj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjogImhuaV9hd3ZhbGlk X25vX2F3cmVhZHkiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MmQiLAo+ PiArwqDCoMKgwqDCoMKgwqAgIk5vZGVUeXBlIjogIjB4NCIsCj4+ICvCoMKgwqDCoMKgwqDCoCAi QnJpZWZEZXNjcmlwdGlvbiI6ICJOdW1iZXIgb2YgY3ljbGVzIHRoZSBITi1JIGJyaWRnZSBpcyBz dGFsbGVkIGJlY2F1c2Ugb2YgYmFja3ByZXNzdXJlIG9uIEFXIGNoYW5uZWwuIiwKPj4gK8KgwqDC oMKgwqDCoMKgICJVbml0IjogImFybV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIkNvbXBhdCI6 ICI0MzQqOzQzNio7NDNjKjs0M2EqIgo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAgewo+PiArwqDC oMKgwqDCoMKgwqAgIkV2ZW50TmFtZSI6ICJobmlfYXdyZWFkeV9ub19hd3ZhbGlkIiwKPj4gK8Kg wqDCoMKgwqDCoMKgICJFdmVudElkQ29kZSI6ICIweDJlIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJO b2RlVHlwZSI6ICIweDQiLAo+PiArwqDCoMKgwqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAi TnVtYmVyIG9mIGN5Y2xlcyB0aGUgQVcgY2hhbm5lbCBpcyB3YWl0aW5nIGZvciBuZXcgcmVxdWVz dHMgZnJvbSBITi1JIGJyaWRnZS4iLAo+PiArwqDCoMKgwqDCoMKgwqAgIlVuaXQiOiAiYXJtX2Nt biIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQ29tcGF0IjogIjQzNCo7NDM2Kjs0M2MqOzQzYSoiCj4+ ICvCoMKgwqAgfSwKPj4gK8KgwqDCoCB7Cj4+ICvCoMKgwqDCoMKgwqDCoCAiRXZlbnROYW1lIjog ImhuaV93dmFsaWRfbm9fd3JlYWR5IiwKPj4gK8KgwqDCoMKgwqDCoMKgICJFdmVudElkQ29kZSI6 ICIweDJmIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJOb2RlVHlwZSI6ICIweDQiLAo+PiArwqDCoMKg wqDCoMKgwqAgIkJyaWVmRGVzY3JpcHRpb24iOiAiTnVtYmVyIG9mIGN5Y2xlcyB0aGUgSE4tSSBi cmlkZ2UgaXMgc3RhbGxlZCBiZWNhdXNlIG9mIGJhY2twcmVzc3VyZSBvbiBXIGNoYW5uZWwuIiwK Pj4gK8KgwqDCoMKgwqDCoMKgICJVbml0IjogImFybV9jbW4iLAo+PiArwqDCoMKgwqDCoMKgwqAg IkNvbXBhdCI6ICI0MzQqOzQzNio7NDNjKjs0M2EqIgo+PiArwqDCoMKgIH0sCj4+ICvCoMKgwqAg ewo+PiArwqDCoMKgwqDCoMKgwqAgIkV2ZW50TmFtZSI6ICJobmlfdHhkYXRfc3RhbGwiLAo+PiAr wqDCoMKgwqDCoMKgwqAgIkV2ZW50SWRDb2RlIjogIjB4MzAiLAo+PiArwqDCoMKgwqDCoMKgwqAg Ik5vZGVUeXBlIjogIjB4NCIsCj4+ICvCoMKgwqDCoMKgwqDCoCAiQnJpZWZEZXNjcmlwdGlvbiI6 ICJUWERBVCB2YWxpZCBidXQgbm8gbGluayBjcmVkaXQgYXZhaWxhYmxlLiIsCj4+ICvCoMKgwqDC oMKgwqDCoCAiVW5pdCI6ICJhcm1fY21uIiwKPj4gK8KgwqDCoMKgwqDCoMKgICJDb21wYXQiOiAi NDM0Kjs0MzYqOzQzYyo7NDNhKiIKPj4gK8KgwqDCoCB9Cj4+ICtdCj4+IGRpZmYgLS1naXQgYS90 b29scy9wZXJmL3BtdS1ldmVudHMvamV2ZW50cy5weSBiL3Rvb2xzL3BlcmYvcG11LWV2ZW50cy9q ZXZlbnRzLnB5Cj4+IGluZGV4IDM2OWM4YmYuLjkzNWJkNGIgMTAwNzU1Cj4+IC0tLSBhL3Rvb2xz L3BlcmYvcG11LWV2ZW50cy9qZXZlbnRzLnB5Cj4+ICsrKyBiL3Rvb2xzL3BlcmYvcG11LWV2ZW50 cy9qZXZlbnRzLnB5Cj4+IEBAIC0yNzIsNiArMjcyLDcgQEAgY2xhc3MgSnNvbkV2ZW50Ogo+PiDC oMKgwqDCoMKgwqDCoMKgwqDCoMKgICdERlBNQyc6ICdhbWRfZGYnLAo+PiDCoMKgwqDCoMKgwqDC oMKgwqDCoMKgICdjcHVfY29yZSc6ICdjcHVfY29yZScsCj4+IMKgwqDCoMKgwqDCoMKgwqDCoMKg wqAgJ2NwdV9hdG9tJzogJ2NwdV9hdG9tJywKPj4gK8KgwqDCoMKgwqDCoMKgwqDCoCAnYXJtX2Nt bic6ICdhcm1fY21uJywKPj4gwqDCoMKgwqDCoMKgwqAgfQo+PiDCoMKgwqDCoMKgwqDCoCByZXR1 cm4gdGFibGVbdW5pdF0gaWYgdW5pdCBpbiB0YWJsZSBlbHNlIGYndW5jb3JlX3t1bml0Lmxvd2Vy KCl9Jwo+PiDCoCAKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fCmxpbnV4LWFybS1rZXJuZWwgbWFpbGluZyBsaXN0CmxpbnV4LWFybS1rZXJuZWxAbGlzdHMu aW5mcmFkZWFkLm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZv L2xpbnV4LWFybS1rZXJuZWwK