From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-alma10-1.taild15c8.ts.net [100.103.45.18]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3BCB737DEBE; Sat, 27 Jun 2026 21:22:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=100.103.45.18 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782595322; cv=none; b=H8O42TNMe/dxLUlEbamrQs4mYYUjwQKgnc7lh44wuaBjkTAlJxjqY/Vg5ibnWj9lMC0j53DIUXQrFOZrQOPVJcCgHJMeup1v0JkX2tbSBEqgO0xscApr1taGqGRC+pevc0PS6jq7Vo1oj5+mmRE/ZOEqK5XcH2AibUMdd6KqO5E= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782595322; c=relaxed/simple; bh=Fi1sJsXvDdbr5TiNG1ZQ0mwkB/0WBJXhm5w8HcQsOfI=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=WYPpdDxpecR3W2amPq3TdTarpKhruyUxKpoSnAWisLcs9Z5hi2W99CrOPbJ+1+QP1PKL5ymsqh/OxTe0nrU1nhnEzIgwj8Smo/jI+oQeLNe4bGwWea4Pv3w3R7ZVcI1XT99MnpOA+dSQANRWxCi0u6z2Re4wGQgz4MwhHjGshFg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=CTcZyUvM; arc=none smtp.client-ip=100.103.45.18 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="CTcZyUvM" Received: by smtp.kernel.org (Postfix) with ESMTPSA id 77C3C1F000E9; Sat, 27 Jun 2026 21:22:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel.org; s=k20260515; t=1782595320; bh=Bcf86Hzsw/x7zxg/mG4FuMFcMosZF81My9ebts7C9Hw=; h=Date:From:To:Cc:Subject:References:In-Reply-To; b=CTcZyUvM1WqqdEtdr8HrkviG3NtbpPcdxP47O3QVTacavefegL7LP8NkHspwoFLfL T8a4v2JX7sIJn4HOPhOZASVjttgmPzFsahuUoF86QaYBWsEk1sSo4fJ/SG2dIpYd6p +pz2SmAI2INhq96GbGD7lJUah2mxAVBEZpSAYNPMOJ7fb8Q2SeeA4xf1H3vypuYk1Z SYBbVPQQ1IfbyMoUo6X+QmblfYx8X9AVqsFVZLUGlajPhmRbxFSE62cfdMcdKMxNeF /tK6duY4N5hrKCjUZlBDr6Y7cameZE9PSYnvNwn48iqGWSxxARkVHsqqsfOWARFZd2 bB3qj15cXuR3Q== Date: Sat, 27 Jun 2026 14:21:59 -0700 From: Drew Fustini To: yunhui cui Cc: Adrien Ricciardi , Alexandre Ghiti , Atish Kumar Patra , Atish Patra , Babu Moger , Ben Horgan , Borislav Petkov , Chen Pei , Conor Dooley , Conor Dooley , Dave Hansen , Dave Martin , Fenghua Yu , Gong Shuai , Gong Shuai , guo.wenjia23@zte.com.cn, James Morse , Kornel =?utf-8?Q?Dul=C4=99ba?= , Krzysztof Kozlowski , liu.qingtao2@zte.com.cn, Liu Zhiwei , Palmer Dabbelt , Paul Walmsley , Peter Newman , Radim =?utf-8?B?S3LEjW3DocWZ?= , Reinette Chatre , Rob Herring , Samuel Holland , Sebastian Andrzej Siewior , Tony Luck , Vasudevan Srinivasan , Ved Shanbhogue , Weiwei Li , linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, x86@kernel.org, devicetree@vger.kernel.org, linux-rt-devel@lists.linux.dev, linux-doc@vger.kernel.org Subject: Re: [External] [PATCH v2 3/8] riscv: Add support for srmcfg CSR from Ssqosid extension Message-ID: References: <20260624-dfustini-atl-sc-cbqri-dt-v2-0-2f8049fd902b@kernel.org> <20260624-dfustini-atl-sc-cbqri-dt-v2-3-2f8049fd902b@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: On Sat, Jun 27, 2026 at 05:11:11PM +0800, yunhui cui wrote: > Hi Drew, Hi, thanks for the reviews. > > On Thu, Jun 25, 2026 at 9:40 AM Drew Fustini wrote: > > > > Add support for the srmcfg CSR defined in the Ssqosid ISA extension. > > The CSR contains two fields: > > > > - Resource Control ID (RCID) for resource allocation > > - Monitoring Counter ID (MCID) for tracking resource usage > > > > Requests from a hart to shared resources are tagged with these IDs, > > allowing resource usage to be associated with the running task. > > > > Add a srmcfg field to thread_struct with the same format as the CSR so > > the scheduler can set the RCID and MCID for each task on context > > switch. A per-cpu cpu_srmcfg variable mirrors the CSR state to avoid > > redundant writes. L1D-hot memory access is faster than a CSR read and > > avoids traps under virtualization. > > > > A per-cpu cpu_srmcfg_default holds the default srmcfg for each CPU as > > set by resctrl CPU group assignment. On context switch, RCID and MCID > > inherit from the CPU default independently: a task whose thread RCID > > field is zero takes the CPU default's RCID, and likewise for MCID. > > > > Link: https://github.com/riscv/riscv-ssqosid/releases/tag/v1.0 > > Assisted-by: Claude:claude-opus-4-7 > > Co-developed-by: Kornel Dulęba > > Signed-off-by: Kornel Dulęba > > Signed-off-by: Drew Fustini [..] > > diff --git a/arch/riscv/include/asm/qos.h b/arch/riscv/include/asm/qos.h > > new file mode 100644 > > index 0000000000000000000000000000000000000000..e9e1d69f3797be5f89785a9b3aa7d9d51c476a8a > > --- /dev/null > > +++ b/arch/riscv/include/asm/qos.h [..] > > +static inline void __switch_to_srmcfg(struct task_struct *next) > > +{ [..] > > + if (thread_srmcfg != __this_cpu_read(cpu_srmcfg)) { > > + /* > > + * Drain stores from the outgoing task before the CSR write > > + * so they retain the previous RCID/MCID tag at the cache > > + * interconnect. > > + */ > > + RISCV_FENCE(rw, o); > > + > > + __this_cpu_write(cpu_srmcfg, thread_srmcfg); > > + csr_write(CSR_SRMCFG, thread_srmcfg); > > + /* > > + * Order the csrw before the new task's loads/stores so they > > + * pick up the new tag. Zicsr 6.1.1 makes CSR writes weakly > > + * ordered (device-output) vs memory ops. Ssqosid v1.0 is > > + * silent so honor the general CSR rule. > > + */ > > + RISCV_FENCE(o, rw); > > This is in the context-switch path and may be expensive in practice. Even if > the target workload is pinned and grouped, unpinned/default-group tasks or > kworkers may still run on those CPUs, causing frequent SRMCFG transitions and > paying two fences each time. > > Is this strict ordering required by the Ssqosid spec or known hardware? If > not, can we make this a trade-off and avoid the fences by default, accepting a > small QoS-tagging inaccuracy around the context-switch boundary? These fences were introduced based on Sashiko feedback on the RFC series. You make a good point that this may be too conservative and some inaccuracy probably would be acceptable. I would be okay with dropping them, and we can reevaluate once more hardware implementations with Ssqosid become public. Thanks, Drew 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 6C40AC43458 for ; Sat, 27 Jun 2026 21:22:35 +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=AriAiAlwI6CKDwQfwlKOevg+ViKXop6UwNfnXSYMCuk=; b=iVvvkJ5J/J17vM oNkyY+PyUfy1kDX6z46ROWEF8MshfF6nh89XCU2ke53xPkn23m9js6vWVEvIGXpU3ML+qwoT8Dnfe 5zGsFkyH6Z0aEp6kgYkjTV2iLnIY6gjSFJeWTGD60tUhEDqkzg/UvkrCSfvzTpK823GaEyLl/CjRx YXooEKUC+gfRS2tOYwGyUxtXw6p7+hAga7CNXGDKLjP8ukDoI7i0ZfAkZ1lgozzPXOJjK9aTPMuTF p15YNtG1Lye0g9ClHfsW+LOFzP+Cm4NOnjlBJEHcj3Uyl8TUOJUgBZ8K4VpJQPFHu+GJufg7Gdkah L5RTCLlzRyYbEq79qZGg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.99.1 #2 (Red Hat Linux)) id 1wdaTU-0000000ClpG-0iFu; Sat, 27 Jun 2026 21:22:04 +0000 Received: from tor.source.kernel.org ([2600:3c04:e001:324:0:1991:8:25]) by bombadil.infradead.org with esmtps (Exim 4.99.1 #2 (Red Hat Linux)) id 1wdaTS-0000000Clp8-3Kzu for linux-riscv@lists.infradead.org; Sat, 27 Jun 2026 21:22:02 +0000 Received: from smtp.kernel.org (quasi.space.kernel.org [100.103.45.18]) by tor.source.kernel.org (Postfix) with ESMTP id 39C166008A; Sat, 27 Jun 2026 21:22:01 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 77C3C1F000E9; Sat, 27 Jun 2026 21:22:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel.org; s=k20260515; t=1782595320; bh=Bcf86Hzsw/x7zxg/mG4FuMFcMosZF81My9ebts7C9Hw=; h=Date:From:To:Cc:Subject:References:In-Reply-To; b=CTcZyUvM1WqqdEtdr8HrkviG3NtbpPcdxP47O3QVTacavefegL7LP8NkHspwoFLfL T8a4v2JX7sIJn4HOPhOZASVjttgmPzFsahuUoF86QaYBWsEk1sSo4fJ/SG2dIpYd6p +pz2SmAI2INhq96GbGD7lJUah2mxAVBEZpSAYNPMOJ7fb8Q2SeeA4xf1H3vypuYk1Z SYBbVPQQ1IfbyMoUo6X+QmblfYx8X9AVqsFVZLUGlajPhmRbxFSE62cfdMcdKMxNeF /tK6duY4N5hrKCjUZlBDr6Y7cameZE9PSYnvNwn48iqGWSxxARkVHsqqsfOWARFZd2 bB3qj15cXuR3Q== Date: Sat, 27 Jun 2026 14:21:59 -0700 From: Drew Fustini To: yunhui cui Cc: Adrien Ricciardi , Alexandre Ghiti , Atish Kumar Patra , Atish Patra , Babu Moger , Ben Horgan , Borislav Petkov , Chen Pei , Conor Dooley , Conor Dooley , Dave Hansen , Dave Martin , Fenghua Yu , Gong Shuai , Gong Shuai , guo.wenjia23@zte.com.cn, James Morse , Kornel =?utf-8?Q?Dul=C4=99ba?= , Krzysztof Kozlowski , liu.qingtao2@zte.com.cn, Liu Zhiwei , Palmer Dabbelt , Paul Walmsley , Peter Newman , Radim =?utf-8?B?S3LEjW3DocWZ?= , Reinette Chatre , Rob Herring , Samuel Holland , Sebastian Andrzej Siewior , Tony Luck , Vasudevan Srinivasan , Ved Shanbhogue , Weiwei Li , linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, x86@kernel.org, devicetree@vger.kernel.org, linux-rt-devel@lists.linux.dev, linux-doc@vger.kernel.org Subject: Re: [External] [PATCH v2 3/8] riscv: Add support for srmcfg CSR from Ssqosid extension Message-ID: References: <20260624-dfustini-atl-sc-cbqri-dt-v2-0-2f8049fd902b@kernel.org> <20260624-dfustini-atl-sc-cbqri-dt-v2-3-2f8049fd902b@kernel.org> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: 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 T24gU2F0LCBKdW4gMjcsIDIwMjYgYXQgMDU6MTE6MTFQTSArMDgwMCwgeXVuaHVpIGN1aSB3cm90 ZToKPiBIaSBEcmV3LAoKSGksIHRoYW5rcyBmb3IgdGhlIHJldmlld3MuCgo+IAo+IE9uIFRodSwg SnVuIDI1LCAyMDI2IGF0IDk6NDDigK9BTSBEcmV3IEZ1c3RpbmkgPGZ1c3RpbmlAa2VybmVsLm9y Zz4gd3JvdGU6Cj4gPgo+ID4gQWRkIHN1cHBvcnQgZm9yIHRoZSBzcm1jZmcgQ1NSIGRlZmluZWQg aW4gdGhlIFNzcW9zaWQgSVNBIGV4dGVuc2lvbi4KPiA+IFRoZSBDU1IgY29udGFpbnMgdHdvIGZp ZWxkczoKPiA+Cj4gPiAgIC0gUmVzb3VyY2UgQ29udHJvbCBJRCAoUkNJRCkgZm9yIHJlc291cmNl IGFsbG9jYXRpb24KPiA+ICAgLSBNb25pdG9yaW5nIENvdW50ZXIgSUQgKE1DSUQpIGZvciB0cmFj a2luZyByZXNvdXJjZSB1c2FnZQo+ID4KPiA+IFJlcXVlc3RzIGZyb20gYSBoYXJ0IHRvIHNoYXJl ZCByZXNvdXJjZXMgYXJlIHRhZ2dlZCB3aXRoIHRoZXNlIElEcywKPiA+IGFsbG93aW5nIHJlc291 cmNlIHVzYWdlIHRvIGJlIGFzc29jaWF0ZWQgd2l0aCB0aGUgcnVubmluZyB0YXNrLgo+ID4KPiA+ IEFkZCBhIHNybWNmZyBmaWVsZCB0byB0aHJlYWRfc3RydWN0IHdpdGggdGhlIHNhbWUgZm9ybWF0 IGFzIHRoZSBDU1Igc28KPiA+IHRoZSBzY2hlZHVsZXIgY2FuIHNldCB0aGUgUkNJRCBhbmQgTUNJ RCBmb3IgZWFjaCB0YXNrIG9uIGNvbnRleHQKPiA+IHN3aXRjaC4gQSBwZXItY3B1IGNwdV9zcm1j ZmcgdmFyaWFibGUgbWlycm9ycyB0aGUgQ1NSIHN0YXRlIHRvIGF2b2lkCj4gPiByZWR1bmRhbnQg d3JpdGVzLiBMMUQtaG90IG1lbW9yeSBhY2Nlc3MgaXMgZmFzdGVyIHRoYW4gYSBDU1IgcmVhZCBh bmQKPiA+IGF2b2lkcyB0cmFwcyB1bmRlciB2aXJ0dWFsaXphdGlvbi4KPiA+Cj4gPiBBIHBlci1j cHUgY3B1X3NybWNmZ19kZWZhdWx0IGhvbGRzIHRoZSBkZWZhdWx0IHNybWNmZyBmb3IgZWFjaCBD UFUgYXMKPiA+IHNldCBieSByZXNjdHJsIENQVSBncm91cCBhc3NpZ25tZW50LiBPbiBjb250ZXh0 IHN3aXRjaCwgUkNJRCBhbmQgTUNJRAo+ID4gaW5oZXJpdCBmcm9tIHRoZSBDUFUgZGVmYXVsdCBp bmRlcGVuZGVudGx5OiBhIHRhc2sgd2hvc2UgdGhyZWFkIFJDSUQKPiA+IGZpZWxkIGlzIHplcm8g dGFrZXMgdGhlIENQVSBkZWZhdWx0J3MgUkNJRCwgYW5kIGxpa2V3aXNlIGZvciBNQ0lELgo+ID4K PiA+IExpbms6IGh0dHBzOi8vZ2l0aHViLmNvbS9yaXNjdi9yaXNjdi1zc3Fvc2lkL3JlbGVhc2Vz L3RhZy92MS4wCj4gPiBBc3Npc3RlZC1ieTogQ2xhdWRlOmNsYXVkZS1vcHVzLTQtNwo+ID4gQ28t ZGV2ZWxvcGVkLWJ5OiBLb3JuZWwgRHVsxJliYSA8bWluZGFsQHNlbWloYWxmLmNvbT4KPiA+IFNp Z25lZC1vZmYtYnk6IEtvcm5lbCBEdWzEmWJhIDxtaW5kYWxAc2VtaWhhbGYuY29tPgo+ID4gU2ln bmVkLW9mZi1ieTogRHJldyBGdXN0aW5pIDxmdXN0aW5pQGtlcm5lbC5vcmc+ClsuLl0KPiA+IGRp ZmYgLS1naXQgYS9hcmNoL3Jpc2N2L2luY2x1ZGUvYXNtL3Fvcy5oIGIvYXJjaC9yaXNjdi9pbmNs dWRlL2FzbS9xb3MuaAo+ID4gbmV3IGZpbGUgbW9kZSAxMDA2NDQKPiA+IGluZGV4IDAwMDAwMDAw MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAuLmU5ZTFkNjlmMzc5N2JlNWY4OTc4NWE5 YjNhYTdkOWQ1MWM0NzZhOGEKPiA+IC0tLSAvZGV2L251bGwKPiA+ICsrKyBiL2FyY2gvcmlzY3Yv aW5jbHVkZS9hc20vcW9zLmgKWy4uXQo+ID4gK3N0YXRpYyBpbmxpbmUgdm9pZCBfX3N3aXRjaF90 b19zcm1jZmcoc3RydWN0IHRhc2tfc3RydWN0ICpuZXh0KQo+ID4gK3sKWy4uXQo+ID4gKyAgICAg ICBpZiAodGhyZWFkX3NybWNmZyAhPSBfX3RoaXNfY3B1X3JlYWQoY3B1X3NybWNmZykpIHsKPiA+ ICsgICAgICAgICAgICAgICAvKgo+ID4gKyAgICAgICAgICAgICAgICAqIERyYWluIHN0b3JlcyBm cm9tIHRoZSBvdXRnb2luZyB0YXNrIGJlZm9yZSB0aGUgQ1NSIHdyaXRlCj4gPiArICAgICAgICAg ICAgICAgICogc28gdGhleSByZXRhaW4gdGhlIHByZXZpb3VzIFJDSUQvTUNJRCB0YWcgYXQgdGhl IGNhY2hlCj4gPiArICAgICAgICAgICAgICAgICogaW50ZXJjb25uZWN0Lgo+ID4gKyAgICAgICAg ICAgICAgICAqLwo+ID4gKyAgICAgICAgICAgICAgIFJJU0NWX0ZFTkNFKHJ3LCBvKTsKPiA+ICsK PiA+ICsgICAgICAgICAgICAgICBfX3RoaXNfY3B1X3dyaXRlKGNwdV9zcm1jZmcsIHRocmVhZF9z cm1jZmcpOwo+ID4gKyAgICAgICAgICAgICAgIGNzcl93cml0ZShDU1JfU1JNQ0ZHLCB0aHJlYWRf c3JtY2ZnKTsKPiA+ICsgICAgICAgICAgICAgICAvKgo+ID4gKyAgICAgICAgICAgICAgICAqIE9y ZGVyIHRoZSBjc3J3IGJlZm9yZSB0aGUgbmV3IHRhc2sncyBsb2Fkcy9zdG9yZXMgc28gdGhleQo+ ID4gKyAgICAgICAgICAgICAgICAqIHBpY2sgdXAgdGhlIG5ldyB0YWcuIFppY3NyIDYuMS4xIG1h a2VzIENTUiB3cml0ZXMgd2Vha2x5Cj4gPiArICAgICAgICAgICAgICAgICogb3JkZXJlZCAoZGV2 aWNlLW91dHB1dCkgdnMgbWVtb3J5IG9wcy4gU3Nxb3NpZCB2MS4wIGlzCj4gPiArICAgICAgICAg ICAgICAgICogc2lsZW50IHNvIGhvbm9yIHRoZSBnZW5lcmFsIENTUiBydWxlLgo+ID4gKyAgICAg ICAgICAgICAgICAqLwo+ID4gKyAgICAgICAgICAgICAgIFJJU0NWX0ZFTkNFKG8sIHJ3KTsKPiAK PiBUaGlzIGlzIGluIHRoZSBjb250ZXh0LXN3aXRjaCBwYXRoIGFuZCBtYXkgYmUgZXhwZW5zaXZl IGluIHByYWN0aWNlLiBFdmVuIGlmCj4gdGhlIHRhcmdldCB3b3JrbG9hZCBpcyBwaW5uZWQgYW5k IGdyb3VwZWQsIHVucGlubmVkL2RlZmF1bHQtZ3JvdXAgdGFza3Mgb3IKPiBrd29ya2VycyBtYXkg c3RpbGwgcnVuIG9uIHRob3NlIENQVXMsIGNhdXNpbmcgZnJlcXVlbnQgU1JNQ0ZHIHRyYW5zaXRp b25zIGFuZAo+IHBheWluZyB0d28gZmVuY2VzIGVhY2ggdGltZS4KPiAKPiBJcyB0aGlzIHN0cmlj dCBvcmRlcmluZyByZXF1aXJlZCBieSB0aGUgU3Nxb3NpZCBzcGVjIG9yIGtub3duIGhhcmR3YXJl PyBJZgo+IG5vdCwgY2FuIHdlIG1ha2UgdGhpcyBhIHRyYWRlLW9mZiBhbmQgYXZvaWQgdGhlIGZl bmNlcyBieSBkZWZhdWx0LCBhY2NlcHRpbmcgYQo+IHNtYWxsIFFvUy10YWdnaW5nIGluYWNjdXJh Y3kgYXJvdW5kIHRoZSBjb250ZXh0LXN3aXRjaCBib3VuZGFyeT8KClRoZXNlIGZlbmNlcyB3ZXJl IGludHJvZHVjZWQgYmFzZWQgb24gU2FzaGlrbyBmZWVkYmFjayBvbiB0aGUgUkZDCnNlcmllcy4g WW91IG1ha2UgYSBnb29kIHBvaW50IHRoYXQgdGhpcyBtYXkgYmUgdG9vIGNvbnNlcnZhdGl2ZSBh bmQgc29tZQppbmFjY3VyYWN5IHByb2JhYmx5IHdvdWxkIGJlIGFjY2VwdGFibGUuIEkgd291bGQg YmUgb2theSB3aXRoIGRyb3BwaW5nCnRoZW0sIGFuZCB3ZSBjYW4gcmVldmFsdWF0ZSBvbmNlIG1v cmUgaGFyZHdhcmUgaW1wbGVtZW50YXRpb25zIHdpdGgKU3Nxb3NpZCBiZWNvbWUgcHVibGljLgoK VGhhbmtzLApEcmV3CgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fXwpsaW51eC1yaXNjdiBtYWlsaW5nIGxpc3QKbGludXgtcmlzY3ZAbGlzdHMuaW5mcmFkZWFk Lm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LXJp c2N2Cg==