From mboxrd@z Thu Jan 1 00:00:00 1970 From: Tvrtko Ursulin Subject: Re: [PATCH 5/7] drm/i915: Expose RPCS (SSEU) configuration to userspace (Gen11 only) Date: Tue, 8 Jan 2019 14:35:45 +0000 Message-ID: <194ae419-90ab-ab6a-0cd4-7994429945f0@linux.intel.com> References: <20190108112252.29002-1-tvrtko.ursulin@linux.intel.com> <20190108112252.29002-6-tvrtko.ursulin@linux.intel.com> <154695736833.11059.10594167743180582093@jlahtine-desk.ger.corp.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8"; Format="flowed" Content-Transfer-Encoding: base64 Return-path: Received: from mga18.intel.com (mga18.intel.com [134.134.136.126]) by gabe.freedesktop.org (Postfix) with ESMTPS id 7E58A6EB24 for ; Tue, 8 Jan 2019 14:35:49 +0000 (UTC) In-Reply-To: <154695736833.11059.10594167743180582093@jlahtine-desk.ger.corp.intel.com> Content-Language: en-US List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" To: Joonas Lahtinen , Intel-gfx@lists.freedesktop.org List-Id: intel-gfx@lists.freedesktop.org Ck9uIDA4LzAxLzIwMTkgMTQ6MjIsIEpvb25hcyBMYWh0aW5lbiB3cm90ZToKPiBRdW90aW5nIFR2 cnRrbyBVcnN1bGluICgyMDE5LTAxLTA4IDEzOjIyOjUwKQo+PiBGcm9tOiBUdnJ0a28gVXJzdWxp biA8dHZydGtvLnVyc3VsaW5AaW50ZWwuY29tPgo+Pgo+PiBXZSB3YW50IHRvIGFsbG93IHVzZXJz cGFjZSB0byByZWNvbmZpZ3VyZSB0aGUgc3Vic2xpY2UgY29uZmlndXJhdGlvbiBvbiBhCj4+IHBl ciBjb250ZXh0IGJhc2lzLgo+Pgo+PiBUaGlzIGlzIHJlcXVpcmVkIGZvciB0aGUgZnVuY3Rpb25h bCByZXF1aXJlbWVudCBvZiBzaHV0dGluZyBkb3duIG5vbi1WTUUKPj4gZW5hYmxlZCBzdWItc2xp Y2VzIG9uIEdlbjExIHBhcnRzLgo+Pgo+PiBUbyBkbyBzbywgd2UgZXhwb3NlIGEgY29udGV4dCBw YXJhbWV0ZXIgdG8gYWxsb3cgYWRqdXN0bWVudCBvZiB0aGUgUlBDUwo+PiByZWdpc3RlciBzdG9y ZWQgd2l0aGluIHRoZSBjb250ZXh0IGltYWdlIChhbmQgY3VycmVudGx5IG5vdCBhY2Nlc3NpYmxl IHZpYQo+PiBMUkkpLgo+Pgo+PiBJZiB0aGUgY29udGV4dCBpcyBhZGp1c3RlZCBiZWZvcmUgZmly c3QgdXNlIG9yIHdoaWxzdCBpZGxlLCB0aGUgYWRqdXN0bWVudAo+PiBpcyBmb3IgImZyZWUiOyBv dGhlcndpc2UgaWYgdGhlIGNvbnRleHQgaXMgYWN0aXZlIHdlIHF1ZXVlIGEgcmVxdWVzdCB0byBk bwo+PiBzbyAodXNpbmcgdGhlIGtlcm5lbCBjb250ZXh0KSwgZm9sbG93aW5nIGFsbCBvdGhlciBh Y3Rpdml0eSBieSB0aGF0Cj4+IGNvbnRleHQsIHdoaWNoIGlzIGFsc28gbWFya2VkIGFzIGJhcnJp ZXIgZm9yIGFsbCBmb2xsb3dpbmcgc3VibWlzc2lvbgo+PiBhZ2FpbnN0IHRoZSBzYW1lIGNvbnRl eHQuCj4+Cj4+IFNpbmNlIHRoZSBvdmVyaGVhZCBvZiBkZXZpY2UgcmUtY29uZmlndXJhdGlvbiBk dXJpbmcgY29udGV4dCBzd2l0Y2hpbmcgY2FuCj4+IGJlIHNpZ25pZmljYW50LCBlc3BlY2lhbGx5 IGluIG11bHRpLWNvbnRleHQgd29ya2xvYWRzLCB3ZSBsaW1pdCB0aGlzIG5ldwo+PiB1QVBJIHRv IG9ubHkgc3VwcG9ydCB0aGUgR2VuMTEgVk1FIHVzZSBjYXNlLiBJbiB0aGlzIHVzZSBjYXNlIGVp dGhlciB0aGUKPj4gZGV2aWNlIGlzIGZ1bGx5IGVuYWJsZWQsIGFuZCBleGFjdGx5IG9uZSBzbGlj ZSBhbmQgaGFsZiBvZiB0aGUgc3Vic2xpY2VzCj4+IGFyZSBlbmFibGVkLgo+Pgo+PiBFeGFtcGxl IHVzYWdlOgo+Pgo+PiAgICAgICAgICBzdHJ1Y3QgZHJtX2k5MTVfZ2VtX2NvbnRleHRfcGFyYW1f c3NldSBzc2V1ID0geyB9Owo+PiAgICAgICAgICBzdHJ1Y3QgZHJtX2k5MTVfZ2VtX2NvbnRleHRf cGFyYW0gYXJnID0KPj4gICAgICAgICAgICAgICAgICB7IC5wYXJhbSA9IEk5MTVfQ09OVEVYVF9Q QVJBTV9TU0VVLAo+PiAgICAgICAgICAgICAgICAgICAgLmN0eF9pZCA9IGdlbV9jb250ZXh0X2Ny ZWF0ZShmZCksCj4+ICAgICAgICAgICAgICAgICAgICAuc2l6ZSA9IHNpemVvZihzc2V1KSwKPj4g ICAgICAgICAgICAgICAgICAgIC52YWx1ZSA9IHRvX3VzZXJfcG9pbnRlcigmc3NldSkKPj4gICAg ICAgICAgICAgICAgICB9Owo+Pgo+PiAgICAgICAgICAvKiBRdWVyeSBkZXZpY2UgZGVmYXVsdHMu ICovCj4+ICAgICAgICAgIGdlbV9jb250ZXh0X2dldF9wYXJhbShmZCwgJmFyZyk7Cj4+Cj4+ICAg ICAgICAgIC8qIFNldCBWTUUgY29uZmlndXJhdGlvbiBvbiBhIDF4Nng4IHBhcnQuICovCj4+ICAg ICAgICAgIHNzZXUuc2xpY2VfbWFzayA9IDB4MTsKPj4gICAgICAgICAgc3NldS5zdWJzbGljZV9t YXNrID0gMHhlMDsKPj4gICAgICAgICAgZ2VtX2NvbnRleHRfc2V0X3BhcmFtKGZkLCAmYXJnKTsK Pj4KPj4gdjI6IEZpeCBvZmZzZXQgb2YgQ1RYX1JfUFdSX0NMS19TVEFURSBpbiBpbnRlbF9scl9j b250ZXh0X3NldF9zc2V1KCkgKExpb25lbCkKPj4KPj4gdjM6IEFkZCBhYmlsaXR5IHRvIHByb2dy YW0gdGhpcyBwZXIgZW5naW5lIChDaHJpcykKPj4KPj4gdjQ6IE1vdmUgbW9zdCBnZXRfc3NldSgp IGludG8gaTkxNV9nZW1fY29udGV4dC5jIChMaW9uZWwpCj4+Cj4+IHY1OiBWYWxpZGF0ZSBzc2V1 IGNvbmZpZ3VyYXRpb24gYWdhaW5zdCB0aGUgZGV2aWNlJ3MgY2FwYWJpbGl0aWVzIChMaW9uZWwp Cj4+Cj4+IHY2OiBDaGFuZ2UgY29udGV4dCBwb3dlcmdhdGluZyBzZXR0aW5ncyB0aHJvdWdoIE1J X1NETSBvbiBrZXJuZWwgY29udGV4dCAoQ2hyaXMpCj4+Cj4+IHY3OiBTeW5jaHJvbml6ZSB0aGUg cmVxdWVzdHMgZm9sbG93aW5nIGEgcG93ZXJnYXRpbmcgc2V0dGluZyBjaGFuZ2UgdXNpbmcgYSBn bG9iYWwKPj4gICAgICBkZXBlbmRlbmN5IChDaHJpcykKPj4gICAgICBJdGVyYXRlIHRpbWVsaW5l cyB0aHJvdWdoIGRldl9wcml2Lmd0LmFjdGl2ZV9yaW5ncyAoVHZydGtvKQo+PiAgICAgIERpc2Fi bGUgUlBDUyBjb25maWd1cmF0aW9uIHNldHRpbmcgZm9yIG5vbiBjYXBhYmxlIHVzZXJzIChMaW9u ZWwvVHZydGtvKQo+Pgo+PiB2ODogcy91bmlvbiBpbnRlbF9zc2V1L3N0cnVjdCBpbnRlbF9zc2V1 LyAoTGlvbmVsKQo+PiAgICAgIHMvZGV2X3ByaXYvaTkxNS8gKFR2cnRrbykKPj4gICAgICBDaGFu Z2UgdWFwaSBjbGFzcy9pbnN0YW5jZSBmaWVsZHMgdG8gdTE2IChUdnJ0a28pCj4+ICAgICAgQnVt cCBtYXNrIGZpZWxkcyB0byA2NGJpdHMgKExpb25lbCkKPj4gICAgICBEb24ndCByZXR1cm4gRVBF Uk0gd2hlbiBkeW5hbWljIHNzZXUgaXMgZGlzYWJsZWQgKFR2cnRrbykKPj4KPj4gdjk6IEltcG9y dCBjb250ZXh0IGltYWdlIGludG8ga2VybmVsIGNvbnRleHQncyBwcGd0dCBvbmx5IHdoZW4KPj4g ICAgICByZWNvbmZpZ3VyaW5nIHBvd2VyZ2F0ZWQgc2xpY2Uvc3Vic2xpY2VzIChDaHJpcykKPj4g ICAgICBVc2UgYWxpYXNpbmcgcHBndHQgd2hlbiBuZWVkZWQgKE1pY2hlbCkKPj4KPj4gVHZydGtv IFVyc3VsaW46Cj4+Cj4+IHYxMDoKPj4gICAqIFVwZGF0ZSBmb3IgdXBzdHJlYW0gY2hhbmdlcy4K Pj4gICAqIFJlcXVlc3Qgc3VibWl0IG5lZWRzIGEgUlBNIHJlZmVyZW5jZS4KPj4gICAqIFJlamVj dCBvbiAhRlVMTF9QUEdUVCBmb3Igc2ltcGxpY2l0eS4KPj4gICAqIFB1bGwgb3V0IGdldC9zZXQg cGFyYW0gdG8gaGVscGVycyBmb3IgcmVhZGFiaWxpdHkgYW5kIGxlc3MgaW5kZW50Lgo+PiAgICog VXNlIGk5MTVfcmVxdWVzdF9hd2FpdF9kbWFfZmVuY2UgaW4gYWRkX2dsb2JhbF9iYXJyaWVyIHRv IHNraXAgd2FpdHMKPj4gICAgIG9uIHRoZSBzYW1lIHRpbWVsaW5lIGFuZCBhdm9pZCBHRU1fQlVH X09OLgo+PiAgICogTm8gbmVlZCB0byBleHBsaWNpdGx5IGFzc2lnbiBhIE5VTEwgcG9pbnRlciB0 byBlbmdpbmUgaW4gbGVnYWN5IG1vZGUuCj4+ICAgKiBObyBuZWVkIHRvIG1vdmUgZ2VuOF9tYWtl X3JwY3MgdXAuCj4+ICAgKiBGYWN0b3JlZCBvdXQgZ2xvYmFsIGJhcnJpZXIgYXMgcHJlcCBwYXRj aC4KPj4gICAqIEFsbG93IHRvIG9ubHkgQ0FQX1NZU19BRE1JTiBpZiAhR2VuMTEuCj4+Cj4+IHYx MToKPj4gICAqIFJlbW92ZSBlbmdpbmUgdmZ1bmMgaW4gZmF2b3VyIG9mIGxvY2FsIGhlbHBlci4g KENocmlzIFdpbHNvbikKPj4gICAqIFN0b3AgcmV0aXJpbmcgcmVxdWVzdHMgYmVmb3JlIHVwZGF0 ZXMgc2luY2UgaXQgaXMgbm90IG5lZWRlZAo+PiAgICAgKENocmlzIFdpbHNvbikKPj4gICAqIElt cGxlbWVudCBkaXJlY3QgQ1BVIHVwZGF0ZSBwYXRoIGZvciBpZGxlIGNvbnRleHRzLiAoQ2hyaXMg V2lsc29uKQo+PiAgICogTGVmdCBzaWRlIGRlcGVuZGVuY3kgbmVlZHMgb25seSBiZSBvbiB0aGUg c2FtZSBjb250ZXh0IHRpbWVsaW5lLgo+PiAgICAgKENocmlzIFdpbHNvbikKPj4gICAqIEl0IGlz IHN1ZmZpY2llbnQgdG8gb3JkZXIgdGhlIHRpbWVsaW5lLiAoQ2hyaXMgV2lsc29uKQo+PiAgICog UmVqZWN0ICFSQ1MgY29uZmlndXJhdGlvbiBhdHRlbXB0cyB3aXRoIC1FTk9ERVYgZm9yIG5vdy4K Pj4KPj4gdjEyOgo+PiAgICogUmViYXNlIGZvciBtYWtlX3JwY3MuCj4+Cj4+IHYxMzoKPj4gICAq IENlbnRyYWxpemUgU1NFVSBub3JtYWxpemF0aW9uIHRvIG1ha2VfcnBjcy4KPj4gICAqIFR5cGUg d2lkdGggY2hlY2tpbmcgKHVBUEkgPC0+IGltcGxlbWVudGF0aW9uKS4KPj4gICAqIEdlbjExIHJl c3RyaWN0aW9ucyB1QVBJIGNoZWNrcy4KPj4gICAqIEdlbjExIHN1YnNsaWNlIGNvdW50IGRpZmZl cmVuY2VzIGhhbmRsaW5nLgo+PiAgIENocmlzIFdpbHNvbjoKPj4gICAqIGFyZ3MtPnNpemUgaGFu ZGxpbmcgZml4ZXMuCj4+ICAgKiBVcGRhdGUgY29udGV4dCBpbWFnZSBmcm9tIEdHVFQuCj4+ICAg KiBQb3N0cG9uZSBjb250ZXh0IGltYWdlIHVwZGF0ZSB0byBwaW5uaW5nLgo+PiAgICogVXNlIGk5 MTVfZ2VtX2FjdGl2ZV9yYXcgaW5zdGVhZCBvZiBsYXN0X3JlcXVlc3Rfb25fZW5naW5lLgo+Pgo+ PiB2MTQ6Cj4+ICAgKiBBZGQgYWN0aXZpdHkgdHJhY2tlciBvbiBpbnRlbF9jb250ZXh0IHRvIGZp eCB0aGUgbGlmZXRpbWUgaXNzdWVzCj4+ICAgICBhbmQgc2ltcGxpZnkgdGhlIGNvZGUuIChDaHJp cyBXaWxzb24pCj4+Cj4+IHYxNToKPj4gICAqIEZpeCBjb250ZXh0IHBpbiBsZWFrIGlmIG5vIHNw YWNlIGluIHJpbmcgYnkgc2ltcGxpZnlpbmcgdGhlCj4+ICAgICBjb250ZXh0IHBpbm5pbmcgc2Vx dWVuY2UuCj4+Cj4+IHYxNjoKPj4gICAqIFJlYmFzZSBmb3IgY29udGV4dCBnZXQvc2V0IHBhcmFt IGxvY2tpbmcgY2hhbmdlcy4KPj4gICAqIEp1c3QgLUVOT0RFViBvbiAhR2VuMTEuIChKb29uYXMp Cj4+Cj4+IHYxNzoKPj4gICAqIEZpeCBvbmUgR2VuMTEgc3Vic2xpY2UgZW5hYmxlbWVudCBydWxl Lgo+PiAgICogSGFuZGxlIGVycm9yIGZyb20gaTkxNV9zd19mZW5jZV9hd2FpdF9zd19mZW5jZV9n ZnAuIChDaHJpcyBXaWxzb24pCj4+Cj4+IHYxODoKPj4gICAqIFVwZGF0ZSBjb21taXQgbWVzc2Fn ZS4gKEpvb25hcykKPj4gICAqIFJlc3RyaWN0IHVBUEkgdG8gVk1FIHVzZSBjYXNlLiAoSm9vbmFz KQo+Pgo+PiB2MTk6Cj4+ICAgKiBSZWJhc2UuCj4+Cj4+IHYyMDoKPj4gICAqIFJlYmFzZSBmb3Ig Y2UtPmFjdGl2ZV90cmFja2VyLgo+Pgo+PiB2MjE6Cj4+ICAgKiBSZWJhc2UgZm9yIElTX0dFTiBj aGFuZ2VzLgo+Pgo+PiB2MjI6Cj4+ICAgKiBSZXNlcnZlIHVBUEkgZm9yIGZsYWdzIHN0cmFpZ2h0 IGF3YXkuIChDaHJpcyBXaWxzb24pCj4+Cj4+IHYyMzoKPj4gICAqIFJlYmFzZSBmb3IgUlVOVElN RV9JTkZPLgo+Pgo+PiBCdWd6aWxsYTogaHR0cHM6Ly9idWdzLmZyZWVkZXNrdG9wLm9yZy9zaG93 X2J1Zy5jZ2k/aWQ9MTAwODk5Cj4+IEJ1Z3ppbGxhOiBodHRwczovL2J1Z3MuZnJlZWRlc2t0b3Au b3JnL3Nob3dfYnVnLmNnaT9pZD0xMDc2MzQKPj4gSXNzdWU6IGh0dHBzOi8vZ2l0aHViLmNvbS9p bnRlbC9tZWRpYS1kcml2ZXIvaXNzdWVzLzI2Nwo+PiBTaWduZWQtb2ZmLWJ5OiBDaHJpcyBXaWxz b24gPGNocmlzQGNocmlzLXdpbHNvbi5jby51az4KPj4gU2lnbmVkLW9mZi1ieTogTGlvbmVsIExh bmR3ZXJsaW4gPGxpb25lbC5nLmxhbmR3ZXJsaW5AaW50ZWwuY29tPgo+PiBDYzogRG1pdHJ5IFJv Z296aGtpbiA8ZG1pdHJ5LnYucm9nb3poa2luQGludGVsLmNvbT4KPj4gQ2M6IFR2cnRrbyBVcnN1 bGluIDx0dnJ0a28udXJzdWxpbkBpbnRlbC5jb20+Cj4+IENjOiBaaGlwZW5nIEdvbmcgPHpoaXBl bmcuZ29uZ0BpbnRlbC5jb20+Cj4+IENjOiBKb29uYXMgTGFodGluZW4gPGpvb25hcy5sYWh0aW5l bkBsaW51eC5pbnRlbC5jb20+Cj4+IFNpZ25lZC1vZmYtYnk6IFR2cnRrbyBVcnN1bGluIDx0dnJ0 a28udXJzdWxpbkBpbnRlbC5jb20+Cj4+IFJldmlld2VkLWJ5OiBDaHJpcyBXaWxzb24gPGNocmlz QGNocmlzLXdpbHNvbi5jby51az4gIyB2MjEKPiAKPiA8U05JUD4KPiAKPj4gKysrIGIvZHJpdmVy cy9ncHUvZHJtL2k5MTUvaW50ZWxfbHJjLmMKPj4gQEAgLTIzNzcsNyArMjM3Nyw5IEBAIHUzMiBn ZW44X21ha2VfcnBjcyhzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqaTkxNSwgc3RydWN0IGludGVs X3NzZXUgKnJlcV9zc2V1KQo+PiAgICAgICAgICAgKiBzdWJzbGljZXMgYXJlIGVuYWJsZWQsIG9y IGEgY291bnQgYmV0d2VlbiBvbmUgYW5kIGZvdXIgb24gdGhlIGZpcnN0Cj4+ICAgICAgICAgICAq IHNsaWNlLgo+PiAgICAgICAgICAgKi8KPj4gLSAgICAgICBpZiAoSVNfR0VOKGk5MTUsIDExKSAm JiBzbGljZXMgPT0gMSAmJiBzdWJzbGljZXMgPj0gNCkgewo+PiArICAgICAgIGlmIChJU19HRU4o aTkxNSwgMTEpICYmCj4+ICsgICAgICAgICAgIHNsaWNlcyA9PSAxICYmCj4+ICsgICAgICAgICAg IHN1YnNsaWNlcyA+IG1pbl90KHU4LCA0LCBod2VpZ2h0OChzc2V1LT5zdWJzbGljZV9tYXNrWzBd KSAvIDIpKSB7Cj4gCj4gQ291bGQgdXNlIGl0J3Mgb3duIHZhcmlhYmxlIG1heF9zdWJzbGljZXMg PSBtaW5fdCguLi4pLgoKVGhlIHZhbHVlIGlzIG5vdCB1c2VkIGVsc2V3aGVyZSBzbyBJIHByZXN1 bWUgeW91IG1lYW4gZm9yIHJlYWRhYmlsaXR5PyBsaWtlOgoKaWYgKElTX0dFTihpOTE1LCAxMSkg JiYgc2xpY2VzID09IDEpIHsKCXU4IG1heF9zdWJzbGljZXMgPSBtaW5fdCh1OCwgNCwgaHdlaWdo dDgoc3NldS0+c3Vic2xpY2VfbWFza1swXSkgLyAyKTsKCglpZiAoc3Vic2xpY2VzID4gbWF4X3N1 YnNsaWNlcykgewoJCUdFTV9CVUdfT04oc3Vic2xpY2VzICYgMSk7CgkJc3Vic2xpY2VfcGcgPSBm YWxzZTsKCQlzbGljZXMgKj0gMjsKCX0KfQoKPwoKSSBhbSBub3QgdG9vIGJvdGhlcmVkIHdpdGgg b25lIHZzIHRoZSBvdGhlciBzbyBkZXBlbmRzIGhvdyBzdHJvbmcgeW91IApzdWdnZXN0LgoKPj4g KysrIGIvaW5jbHVkZS91YXBpL2RybS9pOTE1X2RybS5oCj4+IEBAIC0xNDg2LDkgKzE0ODYsNTIg QEAgc3RydWN0IGRybV9pOTE1X2dlbV9jb250ZXh0X3BhcmFtIHsKPj4gICAjZGVmaW5lICAgSTkx NV9DT05URVhUX01BWF9VU0VSX1BSSU9SSVRZICAgICAgIDEwMjMgLyogaW5jbHVzaXZlICovCj4+ ICAgI2RlZmluZSAgIEk5MTVfQ09OVEVYVF9ERUZBVUxUX1BSSU9SSVRZICAgICAgICAgICAgICAg IDAKPj4gICAjZGVmaW5lICAgSTkxNV9DT05URVhUX01JTl9VU0VSX1BSSU9SSVRZICAgICAgIC0x MDIzIC8qIGluY2x1c2l2ZSAqLwo+PiArICAgICAgIC8qCj4+ICsgICAgICAgICogV2hlbiB1c2lu ZyB0aGUgZm9sbG93aW5nIHBhcmFtLCB2YWx1ZSBzaG91bGQgYmUgYSBwb2ludGVyIHRvCj4+ICsg ICAgICAgICogZHJtX2k5MTVfZ2VtX2NvbnRleHRfcGFyYW1fc3NldS4KPj4gKyAgICAgICAgKi8K Pj4gKyNkZWZpbmUgSTkxNV9DT05URVhUX1BBUkFNX1NTRVUgICAgICAgICAgICAgICAgMHg3Cj4+ ICAgICAgICAgIF9fdTY0IHZhbHVlOwo+PiAgIH07Cj4gCj4gTWF5YmUgd2Ugc2hvdWxkIGFtZW5k IHNvbWUgY29tbWVudHM/Cj4gCj4gLyoKPiAgICogTk9URTogQ2FuIGN1cnJlbnRseSBvbmx5IGJl IHVzZWQgdG8gc3dpdGNoIGJldHdlZW4gVk1FIGVuYWJsZWQKPiAgICogICAgICAgc2xpY2UgY29u ZmlndXJhdGlvbiB2cy4gZnVsbCBvbiBJY2VsYWtlIChHZW4xMSkKPiAgICoKPiAgICogTk9URTog U2xpY2UgY29uZmlndXJhdGlvbiByZXF1ZXN0cyBhcmUgaWdub3JlZCB3aGVuIHBlcmYgaXMgZW5h YmxlZC4KPiAgICovCgpBdCBmaXJzdCBJIHRob3VnaHQgYSBnb29kIGlkZWEgYnV0IG9uIHNlY29u ZCB0aG91Z2h0IGRvIHdlIHdhbnQgdG8gcHV0IApzdWNoIGltcGxlbWVudGF0aW9uIGRldGFpbHMg aW50byB1YXBpIGhlYWRlcnM/IFNlY29uZCBub3RlIG1heWJlLCBidXQgCmZpcnN0IEkgaGF2ZSBh IGZlZWxpbmcgaXMgYmVzdCBsZWZ0IG91dCBzaW5jZSBoZWFkZXJzIGFuZCBrZXJuZWwgYXJlIG5v dCAKc3RyaWN0bHkgdGllZCB1cCBpbiBkZXBsb3ltZW50LiBEb24ndCBrbm93LCB0aGlyZCBvcGlu aW9uIGZyb20gQ2hyaXM/CgpSZWdhcmRzLAoKVHZydGtvCgo+IAo+IFJldmlld2VkLWJ5OiBKb29u YXMgTGFodGluZW4gPGpvb25hcy5sYWh0aW5lbkBsaW51eC5pbnRlbC5jb20+Cj4gCj4gUmVnYXJk cywgSm9vbmFzCj4gCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fCkludGVsLWdmeCBtYWlsaW5nIGxpc3QKSW50ZWwtZ2Z4QGxpc3RzLmZyZWVkZXNrdG9wLm9y ZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2ludGVsLWdm eAo=