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 D5360C433EF for ; Fri, 14 Jan 2022 16:34:19 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230447AbiANQeT (ORCPT ); Fri, 14 Jan 2022 11:34:19 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52074 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229697AbiANQeT (ORCPT ); Fri, 14 Jan 2022 11:34:19 -0500 Received: from mail-wr1-x430.google.com (mail-wr1-x430.google.com [IPv6:2a00:1450:4864:20::430]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9547EC061574 for ; Fri, 14 Jan 2022 08:34:18 -0800 (PST) Received: by mail-wr1-x430.google.com with SMTP id l25so16462251wrb.13 for ; Fri, 14 Jan 2022 08:34:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to; bh=hgvLvmcL7VtrRWogLWzZwDxpHiWtyiII6w4vKtf2o70=; b=hh3VG6pslLH5AMX1/xcVYZui3aTKokR1K49JExC769A8QqG+53HAQK7W3V5OcmQ8Fz bUQcNzrfzlHiwiGhBhrbiynwpLZeEnpY33UrQlMlDq+rE4+xGEI+vr/PnGte7PNLFS12 eespOFscV3uESie8GMSZ4e3tH4NSb/+SZO2unaeliePuXIET0oruuJx12VhkglPVoUMV 4odmfKEmvLwfD9D/DZuejfnxioXpyhuJsrlL7vhXDjh2IdIJizjtz52Mh2hUO46kcDq3 eLsm2y8+3bOt2xy9DNFvEDNP0g9gOsQCWhF+h6SqsGhkY5De6ZtvRdyvPmFrkcLazkL5 V5Sg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to; bh=hgvLvmcL7VtrRWogLWzZwDxpHiWtyiII6w4vKtf2o70=; b=risb03RYUqE2Wa7dtQA3Z9d/myjJLJDT3nPjPOTkjXYUTi5CrubGci9gAPs748MBAg QZOzgQAwjLv0mY8Z3r5aTRi++Jv0EaA3l1Bk6AxpKDLQk9/phmxCXSkmGEhDgQwHHVYN HevVCBLpXD+FcQmjXlToyahPhBoWckcFJp/yccHOil/HDKbKWVK30mxe+Wbapkz6FHTx K14853E5B/OI4YIjF67s99NMihhJi+rHY4Ml1wXUGnkgT8JHmgB/JkqD+gtbYtRPajuh eStx4siQuXvkwp7eLgpLNlEl+T+Ytvel7nRhORmWyz73vtCvTVjZJllf9fmyLoDewYLX H2Dg== X-Gm-Message-State: AOAM532Yn48poopEa82kAaCExYNGtbly7E31KMmGyss880mjMGVMF1oL 7qaqhVaZlwbyhwDo7mqSZ+z7Nw== X-Google-Smtp-Source: ABdhPJxBvt1sHKaC8enz1paljcIA8mk3p7DD71geNphwtNtR7yf/M947OycJN9mwjq8kpRIBlgJtlg== X-Received: by 2002:a5d:430e:: with SMTP id h14mr9231694wrq.99.1642178057047; Fri, 14 Jan 2022 08:34:17 -0800 (PST) Received: from google.com ([31.124.24.179]) by smtp.gmail.com with ESMTPSA id q63sm11777780wme.0.2022.01.14.08.34.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 14 Jan 2022 08:34:16 -0800 (PST) Date: Fri, 14 Jan 2022 16:34:14 +0000 From: Lee Jones To: Zong Li Cc: Jessica Clarke , Michael Turquette , Stephen Boyd , Palmer Dabbelt , Paul Walmsley , linux-clk , linux-riscv Subject: Re: [PATCH v3 RESEND] clk: sifive: Fix W=1 kernel build warning Message-ID: References: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-clk@vger.kernel.org On Fri, 14 Jan 2022, Zong Li wrote: > On Fri, Jan 14, 2022 at 6:07 PM Lee Jones wrote: > > > > On Fri, 14 Jan 2022, Zong Li wrote: > > > > > On Fri, Jan 14, 2022 at 2:13 AM Lee Jones wrote: > > > > > > > > On Thu, 13 Jan 2022, Jessica Clarke wrote: > > > > > > > > > On 13 Jan 2022, at 17:21, Lee Jones wrote: > > > > > > > > > > > > On Thu, 13 Jan 2022, Zong Li wrote: > > > > > > > > > > > >> On Wed, Jan 12, 2022 at 5:09 PM Lee Jones wrote: > > > > > >>> > > > > > >>> On Wed, 12 Jan 2022, Zong Li wrote: > > > > > >>> > > > > > >>>> On Tue, Jan 11, 2022 at 5:32 PM Lee Jones wrote: > > > > > >>>>> > > > > > >>>>> On Tue, 11 Jan 2022, Zong Li wrote: > > > > > >>>>> > > > > > >>>>>> On Mon, Jan 10, 2022 at 5:50 PM Lee Jones wrote: > > > > > >>>>>>> > > > > > >>>>>>> Please improve the subject line. > > > > > >>>>>>> > > > > > >>>>>>> If this is a straight revert, the subject line should reflect that. > > > > > >>>>>>> > > > > > >>>>>>> If not, you need to give us specific information regarding the purpose > > > > > >>>>>>> of this patch. Please read the Git log for better, more forthcoming > > > > > >>>>>>> examples. > > > > > >>>>>>> > > > > > >>>>>> > > > > > >>>>>> It seems to me that this patch is not a straight revert, it provides > > > > > >>>>>> another way to fix the original build warnings, just like > > > > > >>>>>> '487dc7bb6a0c' tried to do. I guess the commit message has described > > > > > >>>>>> what the original warnings is and what the root cause is, it also > > > > > >>>>>> mentioned what is changed in this patch. I'm a bit confused whether we > > > > > >>>>>> need to add fixes tag, it looks like that it might cause some > > > > > >>>>>> misunderstanding? > > > > > >>>>> > > > > > >>>>> I think it's the patch description and subject that is causing the > > > > > >>>>> misunderstanding. > > > > > >>>>> > > > > > >>>> > > > > > >>>> Yes, the subject should be made better. > > > > > >>>> > > > > > >>>>> Please help me with a couple of points and I'll help you draft > > > > > >>>>> something up. > > > > > >>>>> > > > > > >>>>> Firstly, what alerted you to the problem you're attempting to solve? > > > > > >>>>> > > > > > >>>> > > > > > >>>> I recently noticed the code was changed, I guess that I was missing > > > > > >>>> something there. After tracking the log, I found that there is a build > > > > > >>>> warning in the original implementation, and it was already fixed, but > > > > > >>>> it seems to me that there are still some situations there, please help > > > > > >>>> me to see the following illustration. > > > > > >>>> > > > > > >>>>>>>> --- a/drivers/clk/sifive/fu540-prci.c > > > > > >>>>>>>> +++ b/drivers/clk/sifive/fu540-prci.c > > > > > >>>>>>>> @@ -20,7 +20,6 @@ > > > > > >>>>>>>> > > > > > >>>>>>>> #include > > > > > >>>>>>>> > > > > > >>>>>>>> -#include "fu540-prci.h" > > > > > >>>>> > > > > > >>>>> How is this related to the issue/patch? > > > > > >>>>> > > > > > >>>> > > > > > >>>> Let's go back to the version without '487dc7bb6a0c' fix. The > > > > > >>>> prci_clk_fu540 variable is defined in sifive-fu540-prci.h header, > > > > > >>>> however, fu540-prci.c includes this header but doesn't use this > > > > > >>>> variable, so the warnings happen. > > > > > >>>> > > > > > >>>> The easiest way to do it is just removing this line, then the warning > > > > > >>>> could be fixed. But as the '487dc7bb6a0c' or this patch does, the code > > > > > >>>> should be improved, the prci_clk_fu540 variable shouldn't be defined > > > > > >>>> in the header, it should be moved somewhere. > > > > > >>>> > > > > > >>>>>>>> +struct prci_clk_desc prci_clk_fu540 = { > > > > > >>>>>>>> + .clks = __prci_init_clocks_fu540, > > > > > >>>>>>>> + .num_clks = ARRAY_SIZE(__prci_init_clocks_fu540), > > > > > >>>>>>>> +}; > > > > > >>>>> > > > > > >>>>>>>> diff --git a/drivers/clk/sifive/fu540-prci.h b/drivers/clk/sifive/fu540-prci.h > > > > > >>>>>>>> index c220677dc010..931d6cad8c1c 100644 > > > > > >>>>>>>> --- a/drivers/clk/sifive/fu540-prci.h > > > > > >>>>>>>> +++ b/drivers/clk/sifive/fu540-prci.h > > > > > >>>>>>>> @@ -7,10 +7,6 @@ > > > > > >>>>>>>> +extern struct prci_clk_desc prci_clk_fu540; > > > > > >>>>> > > > > > >>>>>>>> diff --git a/drivers/clk/sifive/sifive-prci.c b/drivers/clk/sifive/sifive-prci.c > > > > > >>>>>>>> index 80a288c59e56..916d2fc28b9c 100644 > > > > > >>>>>>>> --- a/drivers/clk/sifive/sifive-prci.c > > > > > >>>>>>>> +++ b/drivers/clk/sifive/sifive-prci.c > > > > > >>>>>>>> @@ -12,11 +12,6 @@ > > > > > >>>>>>>> #include "fu540-prci.h" > > > > > >>>>>>>> #include "fu740-prci.h" > > > > > >>>>>>>> > > > > > >>>>>>>> -static const struct prci_clk_desc prci_clk_fu540 = { > > > > > >>>>>>>> - .clks = __prci_init_clocks_fu540, > > > > > >>>>>>>> - .num_clks = ARRAY_SIZE(__prci_init_clocks_fu540), > > > > > >>>>>>>> -}; > > > > > >>>>>>>> - > > > > > >>>>> > > > > > >>>>> I'm not sure if it's you or I that is missing the point here, but > > > > > >>>>> prci_clk_fu540 is used within *this* file itself: > > > > > >>>>> > > > > > >>>> > > > > > >>>> Here is another situation I mentioned at the beginning, if we'd like > > > > > >>>> to put prci_clk_fu540 here, prci_clk_fu740 should be put here as well. > > > > > >>>> I guess you didn't do that because there is a bug in the original > > > > > >>>> code, fu740-prci.c misused the fu540-prci.h, so there is no build > > > > > >>>> warning on fu740. FU740 still works correctly by misusing the > > > > > >>>> fu540-prci.h header because fu740-prci.c doesn't actually use the > > > > > >>>> prci_clk_fu740 variable, like fu540 we talked about earlier. > > > > > >>>> > > > > > >>>>> static const struct of_device_id sifive_prci_of_match[] = { > > > > > >>>>> {.compatible = "sifive,fu540-c000-prci", .data = &prci_clk_fu540}, > > > > > >>>>> {.compatible = "sifive,fu740-c000-prci", .data = &prci_clk_fu740}, > > > > > >>>>> {} > > > > > >>>>> }; > > > > > >>>>> > > > > > >>>>> So why are you moving it out to somewhere it is *not* used and making > > > > > >>>>> it an extern? This sounds like the opposite to what you'd want? > > > > > >>>> > > > > > >>>> The idea is that sifive-prci.c is the core and common part of PRCI, > > > > > >>>> and I'd like to separate the SoCs-dependent part into SoCs-dependent > > > > > >>>> files, such as fu540-prci.c and fu740-prci.c. The goal is if we add > > > > > >>>> new SoCs in the future, we can just put the SoCs-dependent data > > > > > >>>> structure in the new C file, and do as minimum modification as > > > > > >>>> possible in the core file (i.e. sifive-prci.c). It might also help us > > > > > >>>> to see all SoCs-dependent data in one file, then we don't need to > > > > > >>>> cross many files. Putting these two variables in sifive-pric.c is the > > > > > >>>> right thing to do, but that is why I separate them and make them > > > > > >>>> extern in this patch. > > > > > >>> > > > > > >>> I can see what you are doing, but I don't think this is the right > > > > > >>> thing to do. Please put the struct in the same location as it's > > > > > >>> referenced. > > > > > >> > > > > > >> If we decide to move them into sifive-prci.c (i.e. put it in where > > > > > >> it's referenced.), I worried that we might need to move all stuff > > > > > >> which are in fu540-prci.c and fu740-prci.c. Because 'prci_clk_fu540' > > > > > >> is referenced in sifive-prci.c, whereas '__prci_init_clocks_fu540' is > > > > > >> used by 'prci_clk_fu540', and the almost things in fu540-prci.c are > > > > > >> used by '__prci_init_clocks_fu540'. It seems to be a little bit > > > > > >> difficult to clearly decouple it for modularization which I want to > > > > > >> do. What this patch does might be a accepted way, I hope that you can > > > > > >> consider it again. > > > > > >> > > > > > >>> > > > > > >>> And yes that should also be the case for prci_clk_fu740 and yes, it > > > > > >>> was over-looked because it wasn't causing warnings at build time for > > > > > >>> whatever reason. > > > > > >>> > > > > > >>> IMHO, placing 'struct of_device_id' match tables in headers is also > > > > > >>> odd and is likely the real cause of this strange situation. > > > > > >> > > > > > >> I couldn't see what are you pointing, do you mind give more details > > > > > >> about it? It seems to me that the match table is put in C file (i.e. > > > > > >> sifive-prci.c). > > > > > > > > > > > > Oh, sorry, it's a common source file, rather than a header. > > > > > > > > > > > > Okay, so I went and actually looked at the code this time. > > > > > > > > > > > > If I were you I would move all of the device specific structs and > > > > > > tables into the device specific header files, then delete the device > > > > > > specific source (C) files entirely. > > > > > > > > > > > > There seems to be no good reason for carrying a common source file as > > > > > > well as a source file AND header file for each supported device. > > > > > > IMHO, that's over-complicating things for no apparent gain. > > > > > > > > > > The reason it exists the way it does is that the driver uses the header > > > > > files shipped and used for the device tree bindings, and they give the > > > > > same names to different constants (the first three constants are in > > > > > fact the same so don’t clash, but PRCI_CLK_TLCLK is different between > > > > > the two), so can’t both be in the same translation unit (at least not > > > > > without some gross #undef’ing). In FreeBSD I took the alternate > > > > > approach of just defining our own FU540_ and FU740_ namespaced copies > > > > > of the constants, as drivers do for most things anyway. > > > > > > > > That's a sensible approach. > > > > > > > > One which we use in Linux extensively. > > > > > > Thanks all for the review and suggestions, it is great to me to move > > > all stuff into the specific headers, I only have one question there, > > > is it ok to put the definition of those data structures in header > > > files? That is one of the changes we had done in v2 patch. If it's > > > good to you, I will do it in the next version. Thanks. > > > > Can you give me an example please? > > > > Yes, for the simplest example, we don't usually define 'int a = 1' in > header, we might just declare 'extern int a' in header files. If I > understand correctly, we are going to move all stuff in fu540-prci.c > into fu540-prci.h, so there will be many definitions of variable in > fu540-prci.h. These headers will be used only in one file (i.e. > sifive-prci.c), it might not cause strange behavior, but I'd like to > make sure if it could be accepted and ok to all you guys before I > sending the next version. Everything in fu540-prci.c is suitable for inclusion into a header file. The data there is just made up of populated tables. -- Lee Jones [李琼斯] Principal Technical Lead - Developer Services Linaro.org │ Open source software for Arm SoCs Follow Linaro: Facebook | Twitter | Blog 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 60DB1C433F5 for ; Fri, 14 Jan 2022 16:34:29 +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=5SLaEKug+ozBh0BOmN12UNn1fqQQ2LRSu/N/1HYmEfs=; b=ei93MoMYI3fJKk UGIfteemkXrzjui2D1KRHa15sD+Wx7p3zLE2S87zDHna8+v7rvEqwfQ1e/xKh+Nj8vet9iw4KTBxe JiN6HZ1ZbqAfkLGb8PVVNZ/jvHruOI9TDQXp7GJ8D+RlvuA3vp9oSKOhHXup5FMXbBJxeYP5EvilQ 5bOti/U1pPGxwhodrJ7Kwo5RVpnf1OjwGqsoOPAQYhn9HfjRCXLTcUX/5Ckk2gyoukA/RqWr2cU/2 PGr2wjl2NTioG5icYCiNi1ixrt1FYKtlH7/qCu/i8eLep80ZSmuYm6kjY9Z4+E2lNzOdBL+YD7M9g ynjvlsxE57YAfsCqNBQA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1n8PWw-009mQE-Cl; Fri, 14 Jan 2022 16:34:22 +0000 Received: from mail-wr1-x434.google.com ([2a00:1450:4864:20::434]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1n8PWt-009mOw-0S for linux-riscv@lists.infradead.org; Fri, 14 Jan 2022 16:34:21 +0000 Received: by mail-wr1-x434.google.com with SMTP id o3so16489389wrh.10 for ; Fri, 14 Jan 2022 08:34:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to; bh=hgvLvmcL7VtrRWogLWzZwDxpHiWtyiII6w4vKtf2o70=; b=hh3VG6pslLH5AMX1/xcVYZui3aTKokR1K49JExC769A8QqG+53HAQK7W3V5OcmQ8Fz bUQcNzrfzlHiwiGhBhrbiynwpLZeEnpY33UrQlMlDq+rE4+xGEI+vr/PnGte7PNLFS12 eespOFscV3uESie8GMSZ4e3tH4NSb/+SZO2unaeliePuXIET0oruuJx12VhkglPVoUMV 4odmfKEmvLwfD9D/DZuejfnxioXpyhuJsrlL7vhXDjh2IdIJizjtz52Mh2hUO46kcDq3 eLsm2y8+3bOt2xy9DNFvEDNP0g9gOsQCWhF+h6SqsGhkY5De6ZtvRdyvPmFrkcLazkL5 V5Sg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to; bh=hgvLvmcL7VtrRWogLWzZwDxpHiWtyiII6w4vKtf2o70=; b=5QIVaO4aopgQRszYkhiDQi9IGuAGaGtQIBNErpWb9cEJr5D03aib3G5xefQR1AXEZT IXSa9zFIjysB/gELC+7U4TQ9B/AoZ4Yf8NPG4KnBpi/y7IM5gMrHyk3jdgkJzenf/8bo lZHhjWRd7jKZyqN6Fu7pjLSm2O8Tdr0aWEPW57Gd9X0wi5gf9wB1xLKj9eFcPUBy/oNU aTCNF4bG5Z+dlVHX1Sdgab+7JQpDzH5QHriX8TkcCyk4B1+RQOzhsGsBq7POPI9zKQQS FK61vuzAQG8kJ41KRGreXM79wa6v7hxUFOJtRdntqe2CfP084U77gCYIZMfNpiNO81ZM 0wpw== X-Gm-Message-State: AOAM531vGmz/O1t5lVg4jZsREVfdIGgojEXO0MDG+VOuo5ZklX+wuZti ERNOA3K4qR6IvRz9EPqdE1DeNQ== X-Google-Smtp-Source: ABdhPJxBvt1sHKaC8enz1paljcIA8mk3p7DD71geNphwtNtR7yf/M947OycJN9mwjq8kpRIBlgJtlg== X-Received: by 2002:a5d:430e:: with SMTP id h14mr9231694wrq.99.1642178057047; Fri, 14 Jan 2022 08:34:17 -0800 (PST) Received: from google.com ([31.124.24.179]) by smtp.gmail.com with ESMTPSA id q63sm11777780wme.0.2022.01.14.08.34.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 14 Jan 2022 08:34:16 -0800 (PST) Date: Fri, 14 Jan 2022 16:34:14 +0000 From: Lee Jones To: Zong Li Cc: Jessica Clarke , Michael Turquette , Stephen Boyd , Palmer Dabbelt , Paul Walmsley , linux-clk , linux-riscv Subject: Re: [PATCH v3 RESEND] clk: sifive: Fix W=1 kernel build warning Message-ID: References: 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-20220114_083419_110825_9FAA0692 X-CRM114-Status: GOOD ( 83.84 ) X-BeenThere: linux-riscv@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-riscv" Errors-To: linux-riscv-bounces+linux-riscv=archiver.kernel.org@lists.infradead.org T24gRnJpLCAxNCBKYW4gMjAyMiwgWm9uZyBMaSB3cm90ZToKCj4gT24gRnJpLCBKYW4gMTQsIDIw MjIgYXQgNjowNyBQTSBMZWUgSm9uZXMgPGxlZS5qb25lc0BsaW5hcm8ub3JnPiB3cm90ZToKPiA+ Cj4gPiBPbiBGcmksIDE0IEphbiAyMDIyLCBab25nIExpIHdyb3RlOgo+ID4KPiA+ID4gT24gRnJp LCBKYW4gMTQsIDIwMjIgYXQgMjoxMyBBTSBMZWUgSm9uZXMgPGxlZS5qb25lc0BsaW5hcm8ub3Jn PiB3cm90ZToKPiA+ID4gPgo+ID4gPiA+IE9uIFRodSwgMTMgSmFuIDIwMjIsIEplc3NpY2EgQ2xh cmtlIHdyb3RlOgo+ID4gPiA+Cj4gPiA+ID4gPiBPbiAxMyBKYW4gMjAyMiwgYXQgMTc6MjEsIExl ZSBKb25lcyA8bGVlLmpvbmVzQGxpbmFyby5vcmc+IHdyb3RlOgo+ID4gPiA+ID4gPgo+ID4gPiA+ ID4gPiBPbiBUaHUsIDEzIEphbiAyMDIyLCBab25nIExpIHdyb3RlOgo+ID4gPiA+ID4gPgo+ID4g PiA+ID4gPj4gT24gV2VkLCBKYW4gMTIsIDIwMjIgYXQgNTowOSBQTSBMZWUgSm9uZXMgPGxlZS5q b25lc0BsaW5hcm8ub3JnPiB3cm90ZToKPiA+ID4gPiA+ID4+Pgo+ID4gPiA+ID4gPj4+IE9uIFdl ZCwgMTIgSmFuIDIwMjIsIFpvbmcgTGkgd3JvdGU6Cj4gPiA+ID4gPiA+Pj4KPiA+ID4gPiA+ID4+ Pj4gT24gVHVlLCBKYW4gMTEsIDIwMjIgYXQgNTozMiBQTSBMZWUgSm9uZXMgPGxlZS5qb25lc0Bs aW5hcm8ub3JnPiB3cm90ZToKPiA+ID4gPiA+ID4+Pj4+Cj4gPiA+ID4gPiA+Pj4+PiBPbiBUdWUs IDExIEphbiAyMDIyLCBab25nIExpIHdyb3RlOgo+ID4gPiA+ID4gPj4+Pj4KPiA+ID4gPiA+ID4+ Pj4+PiBPbiBNb24sIEphbiAxMCwgMjAyMiBhdCA1OjUwIFBNIExlZSBKb25lcyA8bGVlLmpvbmVz QGxpbmFyby5vcmc+IHdyb3RlOgo+ID4gPiA+ID4gPj4+Pj4+Pgo+ID4gPiA+ID4gPj4+Pj4+PiBQ bGVhc2UgaW1wcm92ZSB0aGUgc3ViamVjdCBsaW5lLgo+ID4gPiA+ID4gPj4+Pj4+Pgo+ID4gPiA+ ID4gPj4+Pj4+PiBJZiB0aGlzIGlzIGEgc3RyYWlnaHQgcmV2ZXJ0LCB0aGUgc3ViamVjdCBsaW5l IHNob3VsZCByZWZsZWN0IHRoYXQuCj4gPiA+ID4gPiA+Pj4+Pj4+Cj4gPiA+ID4gPiA+Pj4+Pj4+ IElmIG5vdCwgeW91IG5lZWQgdG8gZ2l2ZSB1cyBzcGVjaWZpYyBpbmZvcm1hdGlvbiByZWdhcmRp bmcgdGhlIHB1cnBvc2UKPiA+ID4gPiA+ID4+Pj4+Pj4gb2YgdGhpcyBwYXRjaC4gIFBsZWFzZSBy ZWFkIHRoZSBHaXQgbG9nIGZvciBiZXR0ZXIsIG1vcmUgZm9ydGhjb21pbmcKPiA+ID4gPiA+ID4+ Pj4+Pj4gZXhhbXBsZXMuCj4gPiA+ID4gPiA+Pj4+Pj4+Cj4gPiA+ID4gPiA+Pj4+Pj4KPiA+ID4g PiA+ID4+Pj4+PiBJdCBzZWVtcyB0byBtZSB0aGF0IHRoaXMgcGF0Y2ggaXMgbm90IGEgc3RyYWln aHQgcmV2ZXJ0LCBpdCBwcm92aWRlcwo+ID4gPiA+ID4gPj4+Pj4+IGFub3RoZXIgd2F5IHRvIGZp eCB0aGUgb3JpZ2luYWwgYnVpbGQgd2FybmluZ3MsIGp1c3QgbGlrZQo+ID4gPiA+ID4gPj4+Pj4+ ICc0ODdkYzdiYjZhMGMnIHRyaWVkIHRvIGRvLiBJIGd1ZXNzIHRoZSBjb21taXQgbWVzc2FnZSBo YXMgZGVzY3JpYmVkCj4gPiA+ID4gPiA+Pj4+Pj4gd2hhdCB0aGUgb3JpZ2luYWwgd2FybmluZ3Mg aXMgYW5kIHdoYXQgdGhlIHJvb3QgY2F1c2UgaXMsIGl0IGFsc28KPiA+ID4gPiA+ID4+Pj4+PiBt ZW50aW9uZWQgd2hhdCBpcyBjaGFuZ2VkIGluIHRoaXMgcGF0Y2guIEknbSBhIGJpdCBjb25mdXNl ZCB3aGV0aGVyIHdlCj4gPiA+ID4gPiA+Pj4+Pj4gbmVlZCB0byBhZGQgZml4ZXMgdGFnLCBpdCBs b29rcyBsaWtlIHRoYXQgaXQgbWlnaHQgY2F1c2Ugc29tZQo+ID4gPiA+ID4gPj4+Pj4+IG1pc3Vu ZGVyc3RhbmRpbmc/Cj4gPiA+ID4gPiA+Pj4+Pgo+ID4gPiA+ID4gPj4+Pj4gSSB0aGluayBpdCdz IHRoZSBwYXRjaCBkZXNjcmlwdGlvbiBhbmQgc3ViamVjdCB0aGF0IGlzIGNhdXNpbmcgdGhlCj4g PiA+ID4gPiA+Pj4+PiBtaXN1bmRlcnN0YW5kaW5nLgo+ID4gPiA+ID4gPj4+Pj4KPiA+ID4gPiA+ ID4+Pj4KPiA+ID4gPiA+ID4+Pj4gWWVzLCB0aGUgc3ViamVjdCBzaG91bGQgYmUgbWFkZSBiZXR0 ZXIuCj4gPiA+ID4gPiA+Pj4+Cj4gPiA+ID4gPiA+Pj4+PiBQbGVhc2UgaGVscCBtZSB3aXRoIGEg Y291cGxlIG9mIHBvaW50cyBhbmQgSSdsbCBoZWxwIHlvdSBkcmFmdAo+ID4gPiA+ID4gPj4+Pj4g c29tZXRoaW5nIHVwLgo+ID4gPiA+ID4gPj4+Pj4KPiA+ID4gPiA+ID4+Pj4+IEZpcnN0bHksIHdo YXQgYWxlcnRlZCB5b3UgdG8gdGhlIHByb2JsZW0geW91J3JlIGF0dGVtcHRpbmcgdG8gc29sdmU/ Cj4gPiA+ID4gPiA+Pj4+Pgo+ID4gPiA+ID4gPj4+Pgo+ID4gPiA+ID4gPj4+PiBJIHJlY2VudGx5 IG5vdGljZWQgdGhlIGNvZGUgd2FzIGNoYW5nZWQsIEkgZ3Vlc3MgdGhhdCBJIHdhcyBtaXNzaW5n Cj4gPiA+ID4gPiA+Pj4+IHNvbWV0aGluZyB0aGVyZS4gQWZ0ZXIgdHJhY2tpbmcgdGhlIGxvZywg SSBmb3VuZCB0aGF0IHRoZXJlIGlzIGEgYnVpbGQKPiA+ID4gPiA+ID4+Pj4gd2FybmluZyBpbiB0 aGUgb3JpZ2luYWwgaW1wbGVtZW50YXRpb24sIGFuZCBpdCB3YXMgYWxyZWFkeSBmaXhlZCwgYnV0 Cj4gPiA+ID4gPiA+Pj4+IGl0IHNlZW1zIHRvIG1lIHRoYXQgdGhlcmUgYXJlIHN0aWxsIHNvbWUg c2l0dWF0aW9ucyB0aGVyZSwgcGxlYXNlIGhlbHAKPiA+ID4gPiA+ID4+Pj4gbWUgdG8gc2VlIHRo ZSBmb2xsb3dpbmcgaWxsdXN0cmF0aW9uLgo+ID4gPiA+ID4gPj4+Pgo+ID4gPiA+ID4gPj4+Pj4+ Pj4gLS0tIGEvZHJpdmVycy9jbGsvc2lmaXZlL2Z1NTQwLXByY2kuYwo+ID4gPiA+ID4gPj4+Pj4+ Pj4gKysrIGIvZHJpdmVycy9jbGsvc2lmaXZlL2Z1NTQwLXByY2kuYwo+ID4gPiA+ID4gPj4+Pj4+ Pj4gQEAgLTIwLDcgKzIwLDYgQEAKPiA+ID4gPiA+ID4+Pj4+Pj4+Cj4gPiA+ID4gPiA+Pj4+Pj4+ PiAjaW5jbHVkZSA8ZHQtYmluZGluZ3MvY2xvY2svc2lmaXZlLWZ1NTQwLXByY2kuaD4KPiA+ID4g PiA+ID4+Pj4+Pj4+Cj4gPiA+ID4gPiA+Pj4+Pj4+PiAtI2luY2x1ZGUgImZ1NTQwLXByY2kuaCIK PiA+ID4gPiA+ID4+Pj4+Cj4gPiA+ID4gPiA+Pj4+PiBIb3cgaXMgdGhpcyByZWxhdGVkIHRvIHRo ZSBpc3N1ZS9wYXRjaD8KPiA+ID4gPiA+ID4+Pj4+Cj4gPiA+ID4gPiA+Pj4+Cj4gPiA+ID4gPiA+ Pj4+IExldCdzIGdvIGJhY2sgdG8gdGhlIHZlcnNpb24gd2l0aG91dCAnNDg3ZGM3YmI2YTBjJyBm aXguIFRoZQo+ID4gPiA+ID4gPj4+PiBwcmNpX2Nsa19mdTU0MCB2YXJpYWJsZSBpcyBkZWZpbmVk IGluIHNpZml2ZS1mdTU0MC1wcmNpLmggaGVhZGVyLAo+ID4gPiA+ID4gPj4+PiBob3dldmVyLCBm dTU0MC1wcmNpLmMgaW5jbHVkZXMgdGhpcyBoZWFkZXIgYnV0IGRvZXNuJ3QgdXNlIHRoaXMKPiA+ ID4gPiA+ID4+Pj4gdmFyaWFibGUsIHNvIHRoZSB3YXJuaW5ncyBoYXBwZW4uCj4gPiA+ID4gPiA+ Pj4+Cj4gPiA+ID4gPiA+Pj4+IFRoZSBlYXNpZXN0IHdheSB0byBkbyBpdCBpcyBqdXN0IHJlbW92 aW5nIHRoaXMgbGluZSwgdGhlbiB0aGUgd2FybmluZwo+ID4gPiA+ID4gPj4+PiBjb3VsZCBiZSBm aXhlZC4gQnV0IGFzIHRoZSAnNDg3ZGM3YmI2YTBjJyBvciB0aGlzIHBhdGNoIGRvZXMsIHRoZSBj b2RlCj4gPiA+ID4gPiA+Pj4+IHNob3VsZCBiZSBpbXByb3ZlZCwgdGhlIHByY2lfY2xrX2Z1NTQw IHZhcmlhYmxlIHNob3VsZG4ndCBiZSBkZWZpbmVkCj4gPiA+ID4gPiA+Pj4+IGluIHRoZSBoZWFk ZXIsIGl0IHNob3VsZCBiZSBtb3ZlZCBzb21ld2hlcmUuCj4gPiA+ID4gPiA+Pj4+Cj4gPiA+ID4g PiA+Pj4+Pj4+PiArc3RydWN0IHByY2lfY2xrX2Rlc2MgcHJjaV9jbGtfZnU1NDAgPSB7Cj4gPiA+ ID4gPiA+Pj4+Pj4+PiArICAgICAuY2xrcyA9IF9fcHJjaV9pbml0X2Nsb2Nrc19mdTU0MCwKPiA+ ID4gPiA+ID4+Pj4+Pj4+ICsgICAgIC5udW1fY2xrcyA9IEFSUkFZX1NJWkUoX19wcmNpX2luaXRf Y2xvY2tzX2Z1NTQwKSwKPiA+ID4gPiA+ID4+Pj4+Pj4+ICt9Owo+ID4gPiA+ID4gPj4+Pj4KPiA+ ID4gPiA+ID4+Pj4+Pj4+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2Nsay9zaWZpdmUvZnU1NDAtcHJj aS5oIGIvZHJpdmVycy9jbGsvc2lmaXZlL2Z1NTQwLXByY2kuaAo+ID4gPiA+ID4gPj4+Pj4+Pj4g aW5kZXggYzIyMDY3N2RjMDEwLi45MzFkNmNhZDhjMWMgMTAwNjQ0Cj4gPiA+ID4gPiA+Pj4+Pj4+ PiAtLS0gYS9kcml2ZXJzL2Nsay9zaWZpdmUvZnU1NDAtcHJjaS5oCj4gPiA+ID4gPiA+Pj4+Pj4+ PiArKysgYi9kcml2ZXJzL2Nsay9zaWZpdmUvZnU1NDAtcHJjaS5oCj4gPiA+ID4gPiA+Pj4+Pj4+ PiBAQCAtNywxMCArNyw2IEBACj4gPiA+ID4gPiA+Pj4+Pj4+PiArZXh0ZXJuIHN0cnVjdCBwcmNp X2Nsa19kZXNjIHByY2lfY2xrX2Z1NTQwOwo+ID4gPiA+ID4gPj4+Pj4KPiA+ID4gPiA+ID4+Pj4+ Pj4+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2Nsay9zaWZpdmUvc2lmaXZlLXByY2kuYyBiL2RyaXZl cnMvY2xrL3NpZml2ZS9zaWZpdmUtcHJjaS5jCj4gPiA+ID4gPiA+Pj4+Pj4+PiBpbmRleCA4MGEy ODhjNTllNTYuLjkxNmQyZmMyOGI5YyAxMDA2NDQKPiA+ID4gPiA+ID4+Pj4+Pj4+IC0tLSBhL2Ry aXZlcnMvY2xrL3NpZml2ZS9zaWZpdmUtcHJjaS5jCj4gPiA+ID4gPiA+Pj4+Pj4+PiArKysgYi9k cml2ZXJzL2Nsay9zaWZpdmUvc2lmaXZlLXByY2kuYwo+ID4gPiA+ID4gPj4+Pj4+Pj4gQEAgLTEy LDExICsxMiw2IEBACj4gPiA+ID4gPiA+Pj4+Pj4+PiAjaW5jbHVkZSAiZnU1NDAtcHJjaS5oIgo+ ID4gPiA+ID4gPj4+Pj4+Pj4gI2luY2x1ZGUgImZ1NzQwLXByY2kuaCIKPiA+ID4gPiA+ID4+Pj4+ Pj4+Cj4gPiA+ID4gPiA+Pj4+Pj4+PiAtc3RhdGljIGNvbnN0IHN0cnVjdCBwcmNpX2Nsa19kZXNj IHByY2lfY2xrX2Z1NTQwID0gewo+ID4gPiA+ID4gPj4+Pj4+Pj4gLSAgICAgLmNsa3MgPSBfX3By Y2lfaW5pdF9jbG9ja3NfZnU1NDAsCj4gPiA+ID4gPiA+Pj4+Pj4+PiAtICAgICAubnVtX2Nsa3Mg PSBBUlJBWV9TSVpFKF9fcHJjaV9pbml0X2Nsb2Nrc19mdTU0MCksCj4gPiA+ID4gPiA+Pj4+Pj4+ PiAtfTsKPiA+ID4gPiA+ID4+Pj4+Pj4+IC0KPiA+ID4gPiA+ID4+Pj4+Cj4gPiA+ID4gPiA+Pj4+ PiBJJ20gbm90IHN1cmUgaWYgaXQncyB5b3Ugb3IgSSB0aGF0IGlzIG1pc3NpbmcgdGhlIHBvaW50 IGhlcmUsIGJ1dAo+ID4gPiA+ID4gPj4+Pj4gcHJjaV9jbGtfZnU1NDAgaXMgdXNlZCB3aXRoaW4g KnRoaXMqIGZpbGUgaXRzZWxmOgo+ID4gPiA+ID4gPj4+Pj4KPiA+ID4gPiA+ID4+Pj4KPiA+ID4g PiA+ID4+Pj4gSGVyZSBpcyBhbm90aGVyIHNpdHVhdGlvbiBJIG1lbnRpb25lZCBhdCB0aGUgYmVn aW5uaW5nLCBpZiB3ZSdkIGxpa2UKPiA+ID4gPiA+ID4+Pj4gdG8gcHV0IHByY2lfY2xrX2Z1NTQw IGhlcmUsIHByY2lfY2xrX2Z1NzQwIHNob3VsZCBiZSBwdXQgaGVyZSBhcyB3ZWxsLgo+ID4gPiA+ ID4gPj4+PiBJIGd1ZXNzIHlvdSBkaWRuJ3QgZG8gdGhhdCBiZWNhdXNlIHRoZXJlIGlzIGEgYnVn IGluIHRoZSBvcmlnaW5hbAo+ID4gPiA+ID4gPj4+PiBjb2RlLCBmdTc0MC1wcmNpLmMgbWlzdXNl ZCB0aGUgZnU1NDAtcHJjaS5oLCBzbyB0aGVyZSBpcyBubyBidWlsZAo+ID4gPiA+ID4gPj4+PiB3 YXJuaW5nIG9uIGZ1NzQwLiBGVTc0MCBzdGlsbCB3b3JrcyBjb3JyZWN0bHkgYnkgbWlzdXNpbmcg dGhlCj4gPiA+ID4gPiA+Pj4+IGZ1NTQwLXByY2kuaCBoZWFkZXIgYmVjYXVzZSBmdTc0MC1wcmNp LmMgZG9lc24ndCBhY3R1YWxseSB1c2UgdGhlCj4gPiA+ID4gPiA+Pj4+IHByY2lfY2xrX2Z1NzQw IHZhcmlhYmxlLCBsaWtlIGZ1NTQwIHdlIHRhbGtlZCBhYm91dCBlYXJsaWVyLgo+ID4gPiA+ID4g Pj4+Pgo+ID4gPiA+ID4gPj4+Pj4gc3RhdGljIGNvbnN0IHN0cnVjdCBvZl9kZXZpY2VfaWQgc2lm aXZlX3ByY2lfb2ZfbWF0Y2hbXSA9IHsKPiA+ID4gPiA+ID4+Pj4+ICAgICAgICAgey5jb21wYXRp YmxlID0gInNpZml2ZSxmdTU0MC1jMDAwLXByY2kiLCAuZGF0YSA9ICZwcmNpX2Nsa19mdTU0MH0s Cj4gPiA+ID4gPiA+Pj4+PiAgICAgICAgIHsuY29tcGF0aWJsZSA9ICJzaWZpdmUsZnU3NDAtYzAw MC1wcmNpIiwgLmRhdGEgPSAmcHJjaV9jbGtfZnU3NDB9LAo+ID4gPiA+ID4gPj4+Pj4gICAgICAg ICB7fQo+ID4gPiA+ID4gPj4+Pj4gfTsKPiA+ID4gPiA+ID4+Pj4+Cj4gPiA+ID4gPiA+Pj4+PiBT byB3aHkgYXJlIHlvdSBtb3ZpbmcgaXQgb3V0IHRvIHNvbWV3aGVyZSBpdCBpcyAqbm90KiB1c2Vk IGFuZCBtYWtpbmcKPiA+ID4gPiA+ID4+Pj4+IGl0IGFuIGV4dGVybj8gIFRoaXMgc291bmRzIGxp a2UgdGhlIG9wcG9zaXRlIHRvIHdoYXQgeW91J2Qgd2FudD8KPiA+ID4gPiA+ID4+Pj4KPiA+ID4g PiA+ID4+Pj4gVGhlIGlkZWEgaXMgdGhhdCBzaWZpdmUtcHJjaS5jIGlzIHRoZSBjb3JlIGFuZCBj b21tb24gcGFydCBvZiBQUkNJLAo+ID4gPiA+ID4gPj4+PiBhbmQgSSdkIGxpa2UgdG8gc2VwYXJh dGUgdGhlIFNvQ3MtZGVwZW5kZW50IHBhcnQgaW50byBTb0NzLWRlcGVuZGVudAo+ID4gPiA+ID4g Pj4+PiBmaWxlcywgc3VjaCBhcyBmdTU0MC1wcmNpLmMgYW5kIGZ1NzQwLXByY2kuYy4gVGhlIGdv YWwgaXMgaWYgd2UgYWRkCj4gPiA+ID4gPiA+Pj4+IG5ldyBTb0NzIGluIHRoZSBmdXR1cmUsIHdl IGNhbiBqdXN0IHB1dCB0aGUgU29Dcy1kZXBlbmRlbnQgZGF0YQo+ID4gPiA+ID4gPj4+PiBzdHJ1 Y3R1cmUgaW4gdGhlIG5ldyBDIGZpbGUsIGFuZCBkbyBhcyBtaW5pbXVtIG1vZGlmaWNhdGlvbiBh cwo+ID4gPiA+ID4gPj4+PiBwb3NzaWJsZSBpbiB0aGUgY29yZSBmaWxlIChpLmUuIHNpZml2ZS1w cmNpLmMpLiBJdCBtaWdodCBhbHNvIGhlbHAgdXMKPiA+ID4gPiA+ID4+Pj4gdG8gc2VlIGFsbCBT b0NzLWRlcGVuZGVudCBkYXRhIGluIG9uZSBmaWxlLCB0aGVuIHdlIGRvbid0IG5lZWQgdG8KPiA+ ID4gPiA+ID4+Pj4gY3Jvc3MgbWFueSBmaWxlcy4gUHV0dGluZyB0aGVzZSB0d28gdmFyaWFibGVz IGluIHNpZml2ZS1wcmljLmMgaXMgdGhlCj4gPiA+ID4gPiA+Pj4+IHJpZ2h0IHRoaW5nIHRvIGRv LCBidXQgdGhhdCBpcyB3aHkgSSBzZXBhcmF0ZSB0aGVtIGFuZCBtYWtlIHRoZW0KPiA+ID4gPiA+ ID4+Pj4gZXh0ZXJuIGluIHRoaXMgcGF0Y2guCj4gPiA+ID4gPiA+Pj4KPiA+ID4gPiA+ID4+PiBJ IGNhbiBzZWUgd2hhdCB5b3UgYXJlIGRvaW5nLCBidXQgSSBkb24ndCB0aGluayB0aGlzIGlzIHRo ZSByaWdodAo+ID4gPiA+ID4gPj4+IHRoaW5nIHRvIGRvLiAgUGxlYXNlIHB1dCB0aGUgc3RydWN0 IGluIHRoZSBzYW1lIGxvY2F0aW9uIGFzIGl0J3MKPiA+ID4gPiA+ID4+PiByZWZlcmVuY2VkLgo+ ID4gPiA+ID4gPj4KPiA+ID4gPiA+ID4+IElmIHdlIGRlY2lkZSB0byBtb3ZlIHRoZW0gaW50byBz aWZpdmUtcHJjaS5jIChpLmUuIHB1dCBpdCBpbiB3aGVyZQo+ID4gPiA+ID4gPj4gaXQncyByZWZl cmVuY2VkLiksIEkgd29ycmllZCB0aGF0IHdlIG1pZ2h0IG5lZWQgdG8gbW92ZSBhbGwgc3R1ZmYK PiA+ID4gPiA+ID4+IHdoaWNoIGFyZSBpbiBmdTU0MC1wcmNpLmMgYW5kIGZ1NzQwLXByY2kuYy4g QmVjYXVzZSAncHJjaV9jbGtfZnU1NDAnCj4gPiA+ID4gPiA+PiBpcyByZWZlcmVuY2VkIGluIHNp Zml2ZS1wcmNpLmMsIHdoZXJlYXMgJ19fcHJjaV9pbml0X2Nsb2Nrc19mdTU0MCcgaXMKPiA+ID4g PiA+ID4+IHVzZWQgYnkgJ3ByY2lfY2xrX2Z1NTQwJywgYW5kIHRoZSBhbG1vc3QgdGhpbmdzIGlu IGZ1NTQwLXByY2kuYyBhcmUKPiA+ID4gPiA+ID4+IHVzZWQgYnkgJ19fcHJjaV9pbml0X2Nsb2Nr c19mdTU0MCcuIEl0IHNlZW1zIHRvIGJlIGEgbGl0dGxlIGJpdAo+ID4gPiA+ID4gPj4gZGlmZmlj dWx0IHRvIGNsZWFybHkgZGVjb3VwbGUgaXQgZm9yIG1vZHVsYXJpemF0aW9uIHdoaWNoIEkgd2Fu dCB0bwo+ID4gPiA+ID4gPj4gZG8uIFdoYXQgdGhpcyBwYXRjaCBkb2VzIG1pZ2h0IGJlIGEgYWNj ZXB0ZWQgd2F5LCBJIGhvcGUgdGhhdCB5b3UgY2FuCj4gPiA+ID4gPiA+PiBjb25zaWRlciBpdCBh Z2Fpbi4KPiA+ID4gPiA+ID4+Cj4gPiA+ID4gPiA+Pj4KPiA+ID4gPiA+ID4+PiBBbmQgeWVzIHRo YXQgc2hvdWxkIGFsc28gYmUgdGhlIGNhc2UgZm9yIHByY2lfY2xrX2Z1NzQwIGFuZCB5ZXMsIGl0 Cj4gPiA+ID4gPiA+Pj4gd2FzIG92ZXItbG9va2VkIGJlY2F1c2UgaXQgd2Fzbid0IGNhdXNpbmcg d2FybmluZ3MgYXQgYnVpbGQgdGltZSBmb3IKPiA+ID4gPiA+ID4+PiB3aGF0ZXZlciByZWFzb24u Cj4gPiA+ID4gPiA+Pj4KPiA+ID4gPiA+ID4+PiBJTUhPLCBwbGFjaW5nICdzdHJ1Y3Qgb2ZfZGV2 aWNlX2lkJyBtYXRjaCB0YWJsZXMgaW4gaGVhZGVycyBpcyBhbHNvCj4gPiA+ID4gPiA+Pj4gb2Rk IGFuZCBpcyBsaWtlbHkgdGhlIHJlYWwgY2F1c2Ugb2YgdGhpcyBzdHJhbmdlIHNpdHVhdGlvbi4K PiA+ID4gPiA+ID4+Cj4gPiA+ID4gPiA+PiBJIGNvdWxkbid0IHNlZSB3aGF0IGFyZSB5b3UgcG9p bnRpbmcsIGRvIHlvdSBtaW5kIGdpdmUgbW9yZSBkZXRhaWxzCj4gPiA+ID4gPiA+PiBhYm91dCBp dD8gSXQgc2VlbXMgdG8gbWUgdGhhdCB0aGUgbWF0Y2ggdGFibGUgaXMgcHV0IGluIEMgZmlsZSAo aS5lLgo+ID4gPiA+ID4gPj4gc2lmaXZlLXByY2kuYykuCj4gPiA+ID4gPiA+Cj4gPiA+ID4gPiA+ IE9oLCBzb3JyeSwgaXQncyBhIGNvbW1vbiBzb3VyY2UgZmlsZSwgcmF0aGVyIHRoYW4gYSBoZWFk ZXIuCj4gPiA+ID4gPiA+Cj4gPiA+ID4gPiA+IE9rYXksIHNvIEkgd2VudCBhbmQgYWN0dWFsbHkg bG9va2VkIGF0IHRoZSBjb2RlIHRoaXMgdGltZS4KPiA+ID4gPiA+ID4KPiA+ID4gPiA+ID4gSWYg SSB3ZXJlIHlvdSBJIHdvdWxkIG1vdmUgYWxsIG9mIHRoZSBkZXZpY2Ugc3BlY2lmaWMgc3RydWN0 cyBhbmQKPiA+ID4gPiA+ID4gdGFibGVzIGludG8gdGhlIGRldmljZSBzcGVjaWZpYyBoZWFkZXIg ZmlsZXMsIHRoZW4gZGVsZXRlIHRoZSBkZXZpY2UKPiA+ID4gPiA+ID4gc3BlY2lmaWMgc291cmNl IChDKSBmaWxlcyBlbnRpcmVseS4KPiA+ID4gPiA+ID4KPiA+ID4gPiA+ID4gVGhlcmUgc2VlbXMg dG8gYmUgbm8gZ29vZCByZWFzb24gZm9yIGNhcnJ5aW5nIGEgY29tbW9uIHNvdXJjZSBmaWxlIGFz Cj4gPiA+ID4gPiA+IHdlbGwgYXMgYSBzb3VyY2UgZmlsZSBBTkQgaGVhZGVyIGZpbGUgZm9yIGVh Y2ggc3VwcG9ydGVkIGRldmljZS4KPiA+ID4gPiA+ID4gSU1ITywgdGhhdCdzIG92ZXItY29tcGxp Y2F0aW5nIHRoaW5ncyBmb3Igbm8gYXBwYXJlbnQgZ2Fpbi4KPiA+ID4gPiA+Cj4gPiA+ID4gPiBU aGUgcmVhc29uIGl0IGV4aXN0cyB0aGUgd2F5IGl0IGRvZXMgaXMgdGhhdCB0aGUgZHJpdmVyIHVz ZXMgdGhlIGhlYWRlcgo+ID4gPiA+ID4gZmlsZXMgc2hpcHBlZCBhbmQgdXNlZCBmb3IgdGhlIGRl dmljZSB0cmVlIGJpbmRpbmdzLCBhbmQgdGhleSBnaXZlIHRoZQo+ID4gPiA+ID4gc2FtZSBuYW1l cyB0byBkaWZmZXJlbnQgY29uc3RhbnRzICh0aGUgZmlyc3QgdGhyZWUgY29uc3RhbnRzIGFyZSBp bgo+ID4gPiA+ID4gZmFjdCB0aGUgc2FtZSBzbyBkb27igJl0IGNsYXNoLCBidXQgUFJDSV9DTEtf VExDTEsgaXMgZGlmZmVyZW50IGJldHdlZW4KPiA+ID4gPiA+IHRoZSB0d28pLCBzbyBjYW7igJl0 IGJvdGggYmUgaW4gdGhlIHNhbWUgdHJhbnNsYXRpb24gdW5pdCAoYXQgbGVhc3Qgbm90Cj4gPiA+ ID4gPiB3aXRob3V0IHNvbWUgZ3Jvc3MgI3VuZGVm4oCZaW5nKS4gSW4gRnJlZUJTRCBJIHRvb2sg dGhlIGFsdGVybmF0ZQo+ID4gPiA+ID4gYXBwcm9hY2ggb2YganVzdCBkZWZpbmluZyBvdXIgb3du IEZVNTQwXyBhbmQgRlU3NDBfIG5hbWVzcGFjZWQgY29waWVzCj4gPiA+ID4gPiBvZiB0aGUgY29u c3RhbnRzLCBhcyBkcml2ZXJzIGRvIGZvciBtb3N0IHRoaW5ncyBhbnl3YXkuCj4gPiA+ID4KPiA+ ID4gPiBUaGF0J3MgYSBzZW5zaWJsZSBhcHByb2FjaC4KPiA+ID4gPgo+ID4gPiA+IE9uZSB3aGlj aCB3ZSB1c2UgaW4gTGludXggZXh0ZW5zaXZlbHkuCj4gPiA+Cj4gPiA+IFRoYW5rcyBhbGwgZm9y IHRoZSByZXZpZXcgYW5kIHN1Z2dlc3Rpb25zLCBpdCBpcyBncmVhdCB0byBtZSB0byBtb3ZlCj4g PiA+IGFsbCBzdHVmZiBpbnRvIHRoZSBzcGVjaWZpYyBoZWFkZXJzLCBJIG9ubHkgaGF2ZSBvbmUg cXVlc3Rpb24gdGhlcmUsCj4gPiA+IGlzIGl0IG9rIHRvIHB1dCB0aGUgZGVmaW5pdGlvbiBvZiB0 aG9zZSBkYXRhIHN0cnVjdHVyZXMgaW4gaGVhZGVyCj4gPiA+IGZpbGVzPyBUaGF0IGlzIG9uZSBv ZiB0aGUgY2hhbmdlcyB3ZSBoYWQgZG9uZSBpbiB2MiBwYXRjaC4gSWYgaXQncwo+ID4gPiBnb29k IHRvIHlvdSwgSSB3aWxsIGRvIGl0IGluIHRoZSBuZXh0IHZlcnNpb24uIFRoYW5rcy4KPiA+Cj4g PiBDYW4geW91IGdpdmUgbWUgYW4gZXhhbXBsZSBwbGVhc2U/Cj4gPgo+IAo+IFllcywgZm9yIHRo ZSBzaW1wbGVzdCBleGFtcGxlLCB3ZSBkb24ndCB1c3VhbGx5IGRlZmluZSAnaW50IGEgPSAxJyBp bgo+IGhlYWRlciwgd2UgbWlnaHQganVzdCBkZWNsYXJlICdleHRlcm4gaW50IGEnIGluIGhlYWRl ciBmaWxlcy4gSWYgSQo+IHVuZGVyc3RhbmQgY29ycmVjdGx5LCB3ZSBhcmUgZ29pbmcgdG8gbW92 ZSBhbGwgc3R1ZmYgaW4gZnU1NDAtcHJjaS5jCj4gaW50byBmdTU0MC1wcmNpLmgsIHNvIHRoZXJl IHdpbGwgYmUgbWFueSBkZWZpbml0aW9ucyBvZiB2YXJpYWJsZSBpbgo+IGZ1NTQwLXByY2kuaC4g VGhlc2UgaGVhZGVycyB3aWxsIGJlIHVzZWQgb25seSBpbiBvbmUgZmlsZSAoaS5lLgo+IHNpZml2 ZS1wcmNpLmMpLCBpdCBtaWdodCBub3QgY2F1c2Ugc3RyYW5nZSBiZWhhdmlvciwgYnV0IEknZCBs aWtlIHRvCj4gbWFrZSBzdXJlIGlmIGl0IGNvdWxkIGJlIGFjY2VwdGVkIGFuZCBvayB0byBhbGwg eW91IGd1eXMgYmVmb3JlIEkKPiBzZW5kaW5nIHRoZSBuZXh0IHZlcnNpb24uCgpFdmVyeXRoaW5n IGluIGZ1NTQwLXByY2kuYyBpcyBzdWl0YWJsZSBmb3IgaW5jbHVzaW9uIGludG8gYSBoZWFkZXIK ZmlsZS4gIFRoZSBkYXRhIHRoZXJlIGlzIGp1c3QgbWFkZSB1cCBvZiBwb3B1bGF0ZWQgdGFibGVz LgoKLS0gCkxlZSBKb25lcyBb5p2O55C85pavXQpQcmluY2lwYWwgVGVjaG5pY2FsIExlYWQgLSBE ZXZlbG9wZXIgU2VydmljZXMKTGluYXJvLm9yZyDilIIgT3BlbiBzb3VyY2Ugc29mdHdhcmUgZm9y IEFybSBTb0NzCkZvbGxvdyBMaW5hcm86IEZhY2Vib29rIHwgVHdpdHRlciB8IEJsb2cKCl9fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxpbnV4LXJpc2N2IG1h aWxpbmcgbGlzdApsaW51eC1yaXNjdkBsaXN0cy5pbmZyYWRlYWQub3JnCmh0dHA6Ly9saXN0cy5p bmZyYWRlYWQub3JnL21haWxtYW4vbGlzdGluZm8vbGludXgtcmlzY3YK