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 9D3E7C433F5 for ; Wed, 1 Jun 2022 09:57:26 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351206AbiFAJ5V (ORCPT ); Wed, 1 Jun 2022 05:57:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32826 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350626AbiFAJ5D (ORCPT ); Wed, 1 Jun 2022 05:57:03 -0400 Received: from alexa-out.qualcomm.com (alexa-out.qualcomm.com [129.46.98.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AB37517A95; Wed, 1 Jun 2022 02:57:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1654077421; x=1685613421; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=Y44PZwhmcCgLCiNO57MYn65ly6gAL+sLmXjZbSBb3cE=; b=bKPgOLs3xIy+HzBcM99/8KbNkBrwteMDZ+GAnW9beGBtHAh9hlwdDA6R j+/17eXgCCGgwo1f7hEucgPM7U2XExq24x0G9wEitHoZfVE+1JjPwktHF 1Fm9IONmuN+qBfdOOA0csC//ggYXR+OEhXZ7guA5/3MgxTgm/qaT5DAk2 0=; Received: from ironmsg07-lv.qualcomm.com ([10.47.202.151]) by alexa-out.qualcomm.com with ESMTP; 01 Jun 2022 02:57:01 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg07-lv.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Jun 2022 02:57:01 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Wed, 1 Jun 2022 02:57:00 -0700 Received: from [10.253.36.238] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Wed, 1 Jun 2022 02:56:55 -0700 Message-ID: <2da46bcb-c1e4-dbde-c4ee-1d6983565dc9@quicinc.com> Date: Wed, 1 Jun 2022 17:56:53 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [PATCH v7 02/10] Coresight: Add coresight TPDM source driver Content-Language: en-US To: Suzuki K Poulose , Mathieu Poirier , Alexander Shishkin , Konrad Dybcio , Mike Leach CC: Greg Kroah-Hartman , , , , Tingwei Zhang , Yuanfang Zhang , Tao Zhang , Trilok Soni , Hao Zhang , , Bjorn Andersson References: <20220509133947.20987-1-quic_jinlmao@quicinc.com> <20220509133947.20987-3-quic_jinlmao@quicinc.com> <38bb1ec9-56bc-0cdf-6c46-d448a46ec886@arm.com> <7d6b2e24-21f4-eef1-a722-23cdcd1d8a88@quicinc.com> <006b7edd-20d2-3165-7c83-352b7fb312e7@arm.com> From: Jinlong Mao In-Reply-To: <006b7edd-20d2-3165-7c83-352b7fb312e7@arm.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01a.na.qualcomm.com (10.47.209.196) Precedence: bulk List-ID: X-Mailing-List: linux-arm-msm@vger.kernel.org On 6/1/2022 5:30 PM, Suzuki K Poulose wrote: > On 01/06/2022 10:21, Jinlong Mao wrote: >> Hi Suzuki, >> >> On 5/24/2022 3:00 PM, Jinlong Mao wrote: >>> Hi Suzuki, >>> >>> Thank you for the review. >>> >>> On 5/23/2022 4:57 PM, Suzuki K Poulose wrote: >>>> Hi >>>> >>>> On 09/05/2022 14:39, Mao Jinlong wrote: >>>>> Add driver to support Coresight device TPDM (Trace, Profiling and >>>>> Diagnostics Monitor). TPDM is a monitor to collect data from >>>>> different datasets. This change is to add probe/enable/disable >>>>> functions for tpdm source. >>>>> >>>>> Signed-off-by: Tao Zhang >>>>> Signed-off-by: Mao Jinlong >>>>> --- >>>>>   drivers/hwtracing/coresight/Kconfig          |  13 ++ >>>>>   drivers/hwtracing/coresight/Makefile         |   1 + >>>>>   drivers/hwtracing/coresight/coresight-core.c |   5 +- >>>>>   drivers/hwtracing/coresight/coresight-tpdm.c | 146 >>>>> +++++++++++++++++++ >>>>>   drivers/hwtracing/coresight/coresight-tpdm.h |  26 ++++ >>>>>   include/linux/coresight.h                    |   1 + >>>>>   6 files changed, 191 insertions(+), 1 deletion(-) >>>>>   create mode 100644 drivers/hwtracing/coresight/coresight-tpdm.c >>>>>   create mode 100644 drivers/hwtracing/coresight/coresight-tpdm.h >>>>> >> >>>>> +/** >>>>> + * struct tpdm_drvdata - specifics associated to an TPDM component >>>>> + * @base:       memory mapped base address for this component. >>>>> + * @dev:        The device entity associated to this component. >>>>> + * @csdev:      component vitals needed by the framework. >>>>> + * @lock:       lock for the enable value. >>>>> + * @enable:     enable status of the component. >>>>> + */ >>>>> + >>>>> +struct tpdm_drvdata { >>>>> +    void __iomem        *base; >>>>> +    struct device        *dev; >>>>> +    struct coresight_device    *csdev; >>>>> +    struct mutex        lock; >>>> >>>> Why mutex lock ? Couldn't this be a spinlock ? >>> 1. There is no irq for TPDM >>> 2. As there are 7 dataset types, there will be some FOR loop to >>> configure >>> tpdm registers which may cause some time. > > How long does it take to configure ? Is it too long enough to trigger > RCU stalls ? as long as we don't do any sleeping/blocking operations > we should be fine with a spinlock. > > Suzuki Let me check on internal device and get back to you. Thanks Jinlong Mao > >>> >> I think we can use mutex lock here. Do you have any more comments for >> this ? > >> >> Thanks >> Jinlong Mao >>>> >>>>> +    bool            enable; >>>>> +}; >>>>> + >>>>> +#endif  /* _CORESIGHT_CORESIGHT_TPDM_H */ >>>>> diff --git a/include/linux/coresight.h b/include/linux/coresight.h >>>>> index 247147c11231..a9efac55029d 100644 >>>>> --- a/include/linux/coresight.h >>>>> +++ b/include/linux/coresight.h >>>>> @@ -61,6 +61,7 @@ enum coresight_dev_subtype_source { >>>>>       CORESIGHT_DEV_SUBTYPE_SOURCE_PROC, >>>>>       CORESIGHT_DEV_SUBTYPE_SOURCE_BUS, >>>>>       CORESIGHT_DEV_SUBTYPE_SOURCE_SOFTWARE, >>>>> +    CORESIGHT_DEV_SUBTYPE_SOURCE_DATA_ONLY, >>>> >>>> super minor nit: I find the choice of name a bit odd. >>>> We could simply make it something like : >>>> >>>>     CORESIGHT_DEV_SUBTYPE_SOURCE_OTHERS: >>>> >>>> Suzuki >>> I will check and update. >>>> >>>>>   }; >>>>>     enum coresight_dev_subtype_helper { >>>> >>>> _______________________________________________ >>>> CoreSight mailing list -- coresight@lists.linaro.org >>>> To unsubscribe send an email to coresight-leave@lists.linaro.org >>> _______________________________________________ >>> CoreSight mailing list -- coresight@lists.linaro.org >>> To unsubscribe send an email to coresight-leave@lists.linaro.org > > _______________________________________________ > CoreSight mailing list -- coresight@lists.linaro.org > To unsubscribe send an email to coresight-leave@lists.linaro.org 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 70A95C433F5 for ; Wed, 1 Jun 2022 10:15:33 +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-Type: Content-Transfer-Encoding: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=nSiOyETwMuTl1KlX+LDRLwbdYrCP+G1SYcjtIKYwYIY=; b=ieR5DFIISrr6BV 9k0sXk/oPGli363xJq8c5XHzuSo3j4/7QfAMEla5HZZvgWfxH/LGrXj+0/M8L790fpVlzsbZpdjI2 Wwvy06VLoyf4VslNauq/P6BPdUvKhGnGusg8rpmlGO6FwTH3NEOPeu4KprMmDiSjH/9Yv1aodnJe4 gieB949GIr0x5Eo9pDYXO1QKbEOIveEy8yfOBPQEh257X/CzrHwzGnamUxcpoQntSdaixGZNIZnYS Vr+xfdyaqWXN3XmYOC/zQ9hXKURtAQE6rweGdMnN0UjfHP+2d6PGvUIW4jgCHtx4hNbzLF7aZM66l XKMx4LbeDDPPdWowxoqg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nwLMX-00FCRR-SS; Wed, 01 Jun 2022 10:14:02 +0000 Received: from alexa-out.qualcomm.com ([129.46.98.28]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nwL66-00F55Q-6e for linux-arm-kernel@lists.infradead.org; Wed, 01 Jun 2022 09:57:04 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1654077422; x=1685613422; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=Y44PZwhmcCgLCiNO57MYn65ly6gAL+sLmXjZbSBb3cE=; b=ddwsxKKhH+a/CWUumPtH2749VSdk2i/RJMmfFKaB9OZu1tdk4aVUlFB1 u365JN2Du6duxl0GwuUPyuE8//eaA8kReM2xq+rXS78Hnh5lr0iRgKdAS 2TDRLPXPDhnO+TLq/RPFVyZZdGBtZH8rTz18BTldGgMQ1BJT4nMiTu3RY g=; Received: from ironmsg07-lv.qualcomm.com ([10.47.202.151]) by alexa-out.qualcomm.com with ESMTP; 01 Jun 2022 02:57:01 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg07-lv.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 01 Jun 2022 02:57:01 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Wed, 1 Jun 2022 02:57:00 -0700 Received: from [10.253.36.238] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Wed, 1 Jun 2022 02:56:55 -0700 Message-ID: <2da46bcb-c1e4-dbde-c4ee-1d6983565dc9@quicinc.com> Date: Wed, 1 Jun 2022 17:56:53 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [PATCH v7 02/10] Coresight: Add coresight TPDM source driver Content-Language: en-US To: Suzuki K Poulose , Mathieu Poirier , Alexander Shishkin , Konrad Dybcio , Mike Leach CC: Greg Kroah-Hartman , , , , Tingwei Zhang , Yuanfang Zhang , Tao Zhang , Trilok Soni , Hao Zhang , , Bjorn Andersson References: <20220509133947.20987-1-quic_jinlmao@quicinc.com> <20220509133947.20987-3-quic_jinlmao@quicinc.com> <38bb1ec9-56bc-0cdf-6c46-d448a46ec886@arm.com> <7d6b2e24-21f4-eef1-a722-23cdcd1d8a88@quicinc.com> <006b7edd-20d2-3165-7c83-352b7fb312e7@arm.com> From: Jinlong Mao In-Reply-To: <006b7edd-20d2-3165-7c83-352b7fb312e7@arm.com> X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01a.na.qualcomm.com (10.47.209.196) X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220601_025702_366233_BD4C15B9 X-CRM114-Status: GOOD ( 23.35 ) 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-Transfer-Encoding: base64 Content-Type: text/plain; charset="utf-8"; Format="flowed" Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Ck9uIDYvMS8yMDIyIDU6MzAgUE0sIFN1enVraSBLIFBvdWxvc2Ugd3JvdGU6Cj4gT24gMDEvMDYv MjAyMiAxMDoyMSwgSmlubG9uZyBNYW8gd3JvdGU6Cj4+IEhpIFN1enVraSwKPj4KPj4gT24gNS8y NC8yMDIyIDM6MDAgUE0sIEppbmxvbmcgTWFvIHdyb3RlOgo+Pj4gSGkgU3V6dWtpLAo+Pj4KPj4+ IFRoYW5rIHlvdSBmb3IgdGhlIHJldmlldy4KPj4+Cj4+PiBPbiA1LzIzLzIwMjIgNDo1NyBQTSwg U3V6dWtpIEsgUG91bG9zZSB3cm90ZToKPj4+PiBIaQo+Pj4+Cj4+Pj4gT24gMDkvMDUvMjAyMiAx NDozOSwgTWFvIEppbmxvbmcgd3JvdGU6Cj4+Pj4+IEFkZCBkcml2ZXIgdG8gc3VwcG9ydCBDb3Jl c2lnaHQgZGV2aWNlIFRQRE0gKFRyYWNlLCBQcm9maWxpbmcgYW5kCj4+Pj4+IERpYWdub3N0aWNz IE1vbml0b3IpLiBUUERNIGlzIGEgbW9uaXRvciB0byBjb2xsZWN0IGRhdGEgZnJvbQo+Pj4+PiBk aWZmZXJlbnQgZGF0YXNldHMuIFRoaXMgY2hhbmdlIGlzIHRvIGFkZCBwcm9iZS9lbmFibGUvZGlz YWJsZQo+Pj4+PiBmdW5jdGlvbnMgZm9yIHRwZG0gc291cmNlLgo+Pj4+Pgo+Pj4+PiBTaWduZWQt b2ZmLWJ5OiBUYW8gWmhhbmcgPHF1aWNfdGFvemhhQHF1aWNpbmMuY29tPgo+Pj4+PiBTaWduZWQt b2ZmLWJ5OiBNYW8gSmlubG9uZyA8cXVpY19qaW5sbWFvQHF1aWNpbmMuY29tPgo+Pj4+PiAtLS0K Pj4+Pj4gwqAgZHJpdmVycy9od3RyYWNpbmcvY29yZXNpZ2h0L0tjb25maWfCoMKgwqDCoMKgwqDC oMKgwqAgfMKgIDEzICsrCj4+Pj4+IMKgIGRyaXZlcnMvaHd0cmFjaW5nL2NvcmVzaWdodC9NYWtl ZmlsZcKgwqDCoMKgwqDCoMKgwqAgfMKgwqAgMSArCj4+Pj4+IMKgIGRyaXZlcnMvaHd0cmFjaW5n L2NvcmVzaWdodC9jb3Jlc2lnaHQtY29yZS5jIHzCoMKgIDUgKy0KPj4+Pj4gwqAgZHJpdmVycy9o d3RyYWNpbmcvY29yZXNpZ2h0L2NvcmVzaWdodC10cGRtLmMgfCAxNDYgCj4+Pj4+ICsrKysrKysr KysrKysrKysrKysKPj4+Pj4gwqAgZHJpdmVycy9od3RyYWNpbmcvY29yZXNpZ2h0L2NvcmVzaWdo dC10cGRtLmggfMKgIDI2ICsrKysKPj4+Pj4gwqAgaW5jbHVkZS9saW51eC9jb3Jlc2lnaHQuaMKg wqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIHzCoMKgIDEgKwo+Pj4+PiDCoCA2 IGZpbGVzIGNoYW5nZWQsIDE5MSBpbnNlcnRpb25zKCspLCAxIGRlbGV0aW9uKC0pCj4+Pj4+IMKg IGNyZWF0ZSBtb2RlIDEwMDY0NCBkcml2ZXJzL2h3dHJhY2luZy9jb3Jlc2lnaHQvY29yZXNpZ2h0 LXRwZG0uYwo+Pj4+PiDCoCBjcmVhdGUgbW9kZSAxMDA2NDQgZHJpdmVycy9od3RyYWNpbmcvY29y ZXNpZ2h0L2NvcmVzaWdodC10cGRtLmgKPj4+Pj4KPj4KPj4+Pj4gKy8qKgo+Pj4+PiArICogc3Ry dWN0IHRwZG1fZHJ2ZGF0YSAtIHNwZWNpZmljcyBhc3NvY2lhdGVkIHRvIGFuIFRQRE0gY29tcG9u ZW50Cj4+Pj4+ICsgKiBAYmFzZTrCoMKgwqDCoMKgwqAgbWVtb3J5IG1hcHBlZCBiYXNlIGFkZHJl c3MgZm9yIHRoaXMgY29tcG9uZW50Lgo+Pj4+PiArICogQGRldjrCoMKgwqDCoMKgwqDCoCBUaGUg ZGV2aWNlIGVudGl0eSBhc3NvY2lhdGVkIHRvIHRoaXMgY29tcG9uZW50Lgo+Pj4+PiArICogQGNz ZGV2OsKgwqDCoMKgwqAgY29tcG9uZW50IHZpdGFscyBuZWVkZWQgYnkgdGhlIGZyYW1ld29yay4K Pj4+Pj4gKyAqIEBsb2NrOsKgwqDCoMKgwqDCoCBsb2NrIGZvciB0aGUgZW5hYmxlIHZhbHVlLgo+ Pj4+PiArICogQGVuYWJsZTrCoMKgwqDCoCBlbmFibGUgc3RhdHVzIG9mIHRoZSBjb21wb25lbnQu Cj4+Pj4+ICsgKi8KPj4+Pj4gKwo+Pj4+PiArc3RydWN0IHRwZG1fZHJ2ZGF0YSB7Cj4+Pj4+ICvC oMKgwqAgdm9pZCBfX2lvbWVtwqDCoMKgwqDCoMKgwqAgKmJhc2U7Cj4+Pj4+ICvCoMKgwqAgc3Ry dWN0IGRldmljZcKgwqDCoMKgwqDCoMKgICpkZXY7Cj4+Pj4+ICvCoMKgwqAgc3RydWN0IGNvcmVz aWdodF9kZXZpY2XCoMKgwqAgKmNzZGV2Owo+Pj4+PiArwqDCoMKgIHN0cnVjdCBtdXRleMKgwqDC oMKgwqDCoMKgIGxvY2s7Cj4+Pj4KPj4+PiBXaHkgbXV0ZXggbG9jayA/IENvdWxkbid0IHRoaXMg YmUgYSBzcGlubG9jayA/Cj4+PiAxLiBUaGVyZSBpcyBubyBpcnEgZm9yIFRQRE0KPj4+IDIuIEFz IHRoZXJlIGFyZSA3IGRhdGFzZXQgdHlwZXMsIHRoZXJlIHdpbGwgYmUgc29tZSBGT1IgbG9vcCB0 byAKPj4+IGNvbmZpZ3VyZQo+Pj4gdHBkbSByZWdpc3RlcnMgd2hpY2ggbWF5IGNhdXNlIHNvbWUg dGltZS4KPgo+IEhvdyBsb25nIGRvZXMgaXQgdGFrZSB0byBjb25maWd1cmUgPyBJcyBpdCB0b28g bG9uZyBlbm91Z2ggdG8gdHJpZ2dlcgo+IFJDVSBzdGFsbHMgPyBhcyBsb25nIGFzIHdlIGRvbid0 IGRvIGFueSBzbGVlcGluZy9ibG9ja2luZyBvcGVyYXRpb25zCj4gd2Ugc2hvdWxkIGJlIGZpbmUg d2l0aCBhIHNwaW5sb2NrLgo+Cj4gU3V6dWtpCgpMZXQgbWUgY2hlY2sgb24gaW50ZXJuYWwgZGV2 aWNlIGFuZCBnZXQgYmFjayB0byB5b3UuCgpUaGFua3MKSmlubG9uZyBNYW8KPgo+Pj4KPj4gSSB0 aGluayB3ZSBjYW4gdXNlIG11dGV4IGxvY2sgaGVyZS4gRG8geW91IGhhdmUgYW55IG1vcmUgY29t bWVudHMgZm9yIAo+PiB0aGlzID8KPgo+Pgo+PiBUaGFua3MKPj4gSmlubG9uZyBNYW8KPj4+Pgo+ Pj4+PiArwqDCoMKgIGJvb2zCoMKgwqDCoMKgwqDCoMKgwqDCoMKgIGVuYWJsZTsKPj4+Pj4gK307 Cj4+Pj4+ICsKPj4+Pj4gKyNlbmRpZsKgIC8qIF9DT1JFU0lHSFRfQ09SRVNJR0hUX1RQRE1fSCAq Lwo+Pj4+PiBkaWZmIC0tZ2l0IGEvaW5jbHVkZS9saW51eC9jb3Jlc2lnaHQuaCBiL2luY2x1ZGUv bGludXgvY29yZXNpZ2h0LmgKPj4+Pj4gaW5kZXggMjQ3MTQ3YzExMjMxLi5hOWVmYWM1NTAyOWQg MTAwNjQ0Cj4+Pj4+IC0tLSBhL2luY2x1ZGUvbGludXgvY29yZXNpZ2h0LmgKPj4+Pj4gKysrIGIv aW5jbHVkZS9saW51eC9jb3Jlc2lnaHQuaAo+Pj4+PiBAQCAtNjEsNiArNjEsNyBAQCBlbnVtIGNv cmVzaWdodF9kZXZfc3VidHlwZV9zb3VyY2Ugewo+Pj4+PiDCoMKgwqDCoMKgIENPUkVTSUdIVF9E RVZfU1VCVFlQRV9TT1VSQ0VfUFJPQywKPj4+Pj4gwqDCoMKgwqDCoCBDT1JFU0lHSFRfREVWX1NV QlRZUEVfU09VUkNFX0JVUywKPj4+Pj4gwqDCoMKgwqDCoCBDT1JFU0lHSFRfREVWX1NVQlRZUEVf U09VUkNFX1NPRlRXQVJFLAo+Pj4+PiArwqDCoMKgIENPUkVTSUdIVF9ERVZfU1VCVFlQRV9TT1VS Q0VfREFUQV9PTkxZLAo+Pj4+Cj4+Pj4gc3VwZXIgbWlub3Igbml0OiBJIGZpbmQgdGhlIGNob2lj ZSBvZiBuYW1lIGEgYml0IG9kZC4KPj4+PiBXZSBjb3VsZCBzaW1wbHkgbWFrZSBpdCBzb21ldGhp bmcgbGlrZSA6Cj4+Pj4KPj4+PiDCoMKgwqDCoENPUkVTSUdIVF9ERVZfU1VCVFlQRV9TT1VSQ0Vf T1RIRVJTOgo+Pj4+Cj4+Pj4gU3V6dWtpCj4+PiBJIHdpbGwgY2hlY2sgYW5kIHVwZGF0ZS4KPj4+ Pgo+Pj4+PiDCoCB9Owo+Pj4+PiDCoCDCoCBlbnVtIGNvcmVzaWdodF9kZXZfc3VidHlwZV9oZWxw ZXIgewo+Pj4+Cj4+Pj4gX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX18KPj4+PiBDb3JlU2lnaHQgbWFpbGluZyBsaXN0IC0tIGNvcmVzaWdodEBsaXN0cy5saW5h cm8ub3JnCj4+Pj4gVG8gdW5zdWJzY3JpYmUgc2VuZCBhbiBlbWFpbCB0byBjb3Jlc2lnaHQtbGVh dmVAbGlzdHMubGluYXJvLm9yZwo+Pj4gX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX18KPj4+IENvcmVTaWdodCBtYWlsaW5nIGxpc3QgLS0gY29yZXNpZ2h0QGxp c3RzLmxpbmFyby5vcmcKPj4+IFRvIHVuc3Vic2NyaWJlIHNlbmQgYW4gZW1haWwgdG8gY29yZXNp Z2h0LWxlYXZlQGxpc3RzLmxpbmFyby5vcmcKPgo+IF9fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fCj4gQ29yZVNpZ2h0IG1haWxpbmcgbGlzdCAtLSBjb3Jlc2ln aHRAbGlzdHMubGluYXJvLm9yZwo+IFRvIHVuc3Vic2NyaWJlIHNlbmQgYW4gZW1haWwgdG8gY29y ZXNpZ2h0LWxlYXZlQGxpc3RzLmxpbmFyby5vcmcKCl9fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fCmxpbnV4LWFybS1rZXJuZWwgbWFpbGluZyBsaXN0CmxpbnV4 LWFybS1rZXJuZWxAbGlzdHMuaW5mcmFkZWFkLm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9y Zy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LWFybS1rZXJuZWwK