From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ville =?iso-8859-1?Q?Syrj=E4l=E4?= Subject: Re: [PATCH 2/7] drm/i915: Work around DISPLAY_PHY_CONTROL register corruption on CHV Date: Fri, 8 May 2015 16:19:13 +0300 Message-ID: <20150508131913.GE18908@intel.com> References: <1428679293-6208-1-git-send-email-ville.syrjala@linux.intel.com> <1428679293-6208-3-git-send-email-ville.syrjala@linux.intel.com> <554CB212.5090800@linux.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mga09.intel.com (mga09.intel.com [134.134.136.24]) by gabe.freedesktop.org (Postfix) with ESMTP id 0FAA76E183 for ; Fri, 8 May 2015 06:19:22 -0700 (PDT) Content-Disposition: inline In-Reply-To: <554CB212.5090800@linux.intel.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" To: Deepak S Cc: intel-gfx@lists.freedesktop.org List-Id: intel-gfx@lists.freedesktop.org T24gRnJpLCBNYXkgMDgsIDIwMTUgYXQgMDY6MjQ6NDJQTSArMDUzMCwgRGVlcGFrIFMgd3JvdGU6 Cj4gCj4gCj4gT24gRnJpZGF5IDEwIEFwcmlsIDIwMTUgMDg6NTEgUE0sIHZpbGxlLnN5cmphbGFA bGludXguaW50ZWwuY29tIHdyb3RlOgo+ID4gRnJvbTogVmlsbGUgU3lyasOkbMOkIDx2aWxsZS5z eXJqYWxhQGxpbnV4LmludGVsLmNvbT4KPiA+Cj4gPiBTb21ldGltZXMgKGV4YWN0bHkgd2hlbiBp cyBhIGJpdCB1bmNsZWFyKSBESVNQTEFZX1BIWV9DT05UUk9MIGFwcGVhcnMgdG8KPiA+IGdldCBj b3JydXB0ZWQuIFRoZSB2YWx1ZXMgSSd2ZSBtYW5hZ2VkIHRvIHJlYWQgZnJvbSBpdCBzZWVtIHRv IGhhdmUgc29tZQo+ID4gcGF0dGVybiBidXQgdmFyeSBxdWl0ZSBhIGxvdC4gVGhlIGNvcnJ1cHRp b24gZG9lc24ndCBzZWVtIHRvIGp1c3QgaGFwcGVuCj4gPiB3aGVuIHRoZSByZWdpc3RlciBpcyBh Y2Nlc3NlZCwgYnV0IGNhbiBhbHNvIGhhcHBlbiBzcG9udGFuZW9zbHkgZHVyaW5nCj4gPiBtb2Rl c2V0LiBXaGVuIHRoaXMgaGFwcGVucyBkdXJpbmcgYSBtb2Rlc2V0IHRoaW5ncyBnbyBzb3V0aCBh bmQgdGhlCj4gPiBkaXNwbGF5IGRvZXNuJ3QgbGlnaHQgdXAuCj4gPgo+ID4gSSd2ZSBtYW5hZ2Vk IHRvIGhpdCB0aGUgcHJvYmxlbW4gd2hlbiB0b2dnbGluZyBIRE1JIG9uIHBvcnQgRCBvbiBhbmQK PiA+IG9mZi4gV2hlbiB0aGluZ3MgZ2V0IGNvcnJ1cHRlZCB0aGUgZGlzcGxheSBkb2Vzbid0IGxp Z2h0IHVwLCBidXQgYXMgc29vbgo+ID4gYXMgSSBtYW51YWxseSB3cml0ZSB0aGUgY29ycmVjdCB2 YWx1ZSB0byB0aGUgcmVnaXN0ZXIgdGhlIGRpc3BsYXkgY29tZXMKPiA+IHVwLgo+ID4KPiA+IEZp cnN0IEkgd2FzIHN1c3BpY2lvdXMgdGhhdCB3ZSBvdXJzZWx2ZXMgYWNjaWRlbnRhbGx5IG92ZXJ3 cml0ZSBpdCB3aXRoCj4gPiBnYXJiYWdlLCBidXQgZGlkbid0IGNhdGNoIGFueXRoaW5nIHdpdGgg dGhlIHJlZ19ydyB0cmFjZXBvaW50LiBBbHNvIEkKPiA+IHNwcmlua2xlZCBjaGVjayBhbGwgb3Zl ciB0aGUgbW9kZXNldCBwYXRoIHRvIHNlZSBleGFjdGx5IHdoZW4gdGhlCj4gPiBjb3JydXB0aW9u IGhhcHBlbnMsIGFuZCBlZy4gdGhlIHJlYWQgYmFjayB2YWx1ZSB3YXMgZmluZSBqdXN0IGJlZm9y ZQo+ID4gaW50ZWxfZHBfc2V0X20oKSwgYW5kIGNvcnJ1cHRlZCBpbW1lZGlhdGVseSBhZnRlciBp dC4gSSBhbHNvIG1hZGUgbXkKPiA+IGNoZWNrIGZ1bmN0aW9uIHJlcGFpciB0aGUgcmVnaXN0ZXIg dmFsdWUgd2hlbmV2ZXIgaXQgd2FzIHdyb25nLCBhbmQgd2l0aAo+ID4gdGhpcyBhcHByb2FjaCB0 aGUgY29ycnVwdGlvbiByZXBlYXRlZCBzZXZlcmFsIHRpbWVzIGR1cmluZyB0aGUgbW9kZXNldAo+ ID4gb3BlcmF0aW9uLCBhbHdheXMgc2VlbWluZyB0byB0cmlnZ2VyIGluIHRoZSBzYW1lIGV4YWN0 IGNhbGxzIHRvIHRoZQo+ID4gY2hlY2sgZnVuY3Rpb24sIHdoaWxlIG90aGVyIGNhbGxzIHRvIHRo ZSBmdW5jdGlvbiBuZXZlciBjYXVnaHQgYW55dGhpbmcuCj4gPgo+ID4gU28gZmFyIEkndmUgbm90 IHNlZW4gdGhpcyBwcm9ibGVtIG9jY3VycmluZyB3aGVuIGNhcmVmdWxseSBhdm9pZGluZyBhbGwK PiA+IHJlYWQgYWNjZXNzZXMgdG8gRElTUExBWV9QSFlfQ09OVFJPTC4gTm90IHN1cmUgaWYgdGhh dCdzIGp1c3QgcHVyZSBsdWNrCj4gPiBvciBhbiBhY3R1YWwgd29ya2Fyb3VuZCwgYnV0IHdlIGNh biBob3BlIGl0IHdvcmtzLiBTbyBsZXQncyBhdm9pZCByZWFkaW5nCj4gPiB0aGUgcmVnaXN0ZXIg YW5kIGluc3RlYWQgdHJhY2sgdGhlIGRlc2lyZWQgdmFsdWUgb2YgdGhlIHJlZ2lzdGVyIGluIGRl dl9wcml2Lgo+ID4KPiA+IHYyOiBSZWFkIG91dCB0aGUgcG93ZXIgd2VsbCBzdGF0ZSB0byBkZXRl cm1pbmUgaW5pdGlhbCByZWdpc3RlciB2YWx1ZQo+ID4gdjM6IFVzZSBEUElPX0NIeCBuYW1lcyBp bnN0ZWFkIG9mIHJhdyBudW1iZXJzCj4gCj4gRXZlbiByZWFkaW5nIG9uY2UgRElTUExBWV9QSFlf Q09OVFJPTCBsYXllciBpcyBnZXR0aW5nIGNvcnJ1cHRlZD8KCk5vdCBhbHdheXMuIEkgdGhpbmsg aXQgc29tZWhvdyBkZXBlbmRzIG9uIHdoYXQgb3RoZXIgcmVnaXN0ZXIgYWNjZXNzZXMKaGFwcGVu IGFyb3VuZCBpdC4gU28gdGhlcmUgaXMgcGVyaGFwcyBzb21lIG1hZ2ljIHNlcXVlbmNlIHRoYXQg bWlnaHQgYWxsb3cKcmVhZGluZyBpdCwgYnV0IEkgZGVjaWRlZCB0aGF0IGl0J3MgYmV0dGVyIHRv IGJlIHNhZmUgYW5kIG5ldmVyIHJlYWQgaXQuCgo+IEkgc2F3IHNpbWlsYXIgaXNzdWVzIG9uIG15 IHNldHVwLiBPbiBzb21lIHBsYXRmb3JtIGFjY2VzcyBwaHkgaXMgY2F1c2luZyBzeXN0ZW0gYmVo YXZlIGluY29uc2lzdGVudGx5ICA6KAo+IAo+ID4gU2lnbmVkLW9mZi1ieTogVmlsbGUgU3lyasOk bMOkIDx2aWxsZS5zeXJqYWxhQGxpbnV4LmludGVsLmNvbT4KPiA+IC0tLQo+ID4gICBkcml2ZXJz L2dwdS9kcm0vaTkxNS9pOTE1X2Rydi5oICAgICAgICAgfCAgMiArKwo+ID4gICBkcml2ZXJzL2dw dS9kcm0vaTkxNS9pOTE1X3JlZy5oICAgICAgICAgfCAgNSArKysrLQo+ID4gICBkcml2ZXJzL2dw dS9kcm0vaTkxNS9pbnRlbF9ydW50aW1lX3BtLmMgfCAzNiArKysrKysrKysrKysrKysrKysrKysr KysrKysrLS0tLS0KPiA+ICAgMyBmaWxlcyBjaGFuZ2VkLCAzNyBpbnNlcnRpb25zKCspLCA2IGRl bGV0aW9ucygtKQo+ID4KPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1 X2Rydi5oIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9kcnYuaAo+ID4gaW5kZXggODIyZjI1 OS4uMjg4YzNmYyAxMDA2NDQKPiA+IC0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfZHJ2 LmgKPiA+ICsrKyBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfZHJ2LmgKPiA+IEBAIC0xNzU0 LDYgKzE3NTQsOCBAQCBzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSB7Cj4gPiAgIAo+ID4gICAJdTMy IGZkaV9yeF9jb25maWc7Cj4gPiAgIAo+ID4gKwl1MzIgY2h2X3BoeV9jb250cm9sOwo+ID4gKwo+ ID4gICAJdTMyIHN1c3BlbmRfY291bnQ7Cj4gPiAgIAlzdHJ1Y3QgaTkxNV9zdXNwZW5kX3NhdmVk X3JlZ2lzdGVycyByZWdmaWxlOwo+ID4gICAJc3RydWN0IHZsdl9zMGl4X3N0YXRlIHZsdl9zMGl4 X3N0YXRlOwo+ID4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfcmVnLmgg Yi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1X3JlZy5oCj4gPiBpbmRleCBjZmJkNWE2Li45ODU4 OGQ1IDEwMDY0NAo+ID4gLS0tIGEvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9yZWcuaAo+ID4g KysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9yZWcuaAo+ID4gQEAgLTE4ODcsNyArMTg4 NywxMCBAQCBlbnVtIHNrbF9kaXNwX3Bvd2VyX3dlbGxzIHsKPiA+ICAgI2RlZmluZSBEUElPX1BI WV9TVEFUVVMJCQkoVkxWX0RJU1BMQVlfQkFTRSArIDB4NjI0MCkKPiA+ICAgI2RlZmluZSAgIERQ TExfUE9SVERfUkVBRFlfTUFTSwkJKDB4ZikKPiA+ICAgI2RlZmluZSBESVNQTEFZX1BIWV9DT05U Uk9MIChWTFZfRElTUExBWV9CQVNFICsgMHg2MDEwMCkKPiA+IC0jZGVmaW5lICAgUEhZX0NPTV9M QU5FX1JFU0VUX0RFQVNTRVJUKHBoeSkgKDEgPDwgKHBoeSkpCj4gPiArI2RlZmluZSAgIFBIWV9D SF9TVV9QU1IJCQkJMHgxCj4gPiArI2RlZmluZSAgIFBIWV9DSF9ERUVQX1BTUgkJCTB4Nwo+IAo+ IFBIWV9DSF9ERUVQX1BTUiBkZWZpbmVkIGJ1dCBub3QgdXNlZCBpbiB0aGlzIHBhdGNoPwoKSnVz dCB3YW50ZWQgdG8gZGVmaW5lIGl0IHNpbmNlIGl0J3MgdGhlIG9ubHkgb3RoZXIgdmFsaWQgdmFs dWUsIGFuZCB0aGUKZG9jIHNpdHVhdGlvbiBpcyBjcmFwLiBJJ3ZlIG5vdCBwbGF5ZWQgYXJvdW5k IHdpdGggUFNSIHNvIEknbSBub3QKZW50aXJlbHkgc3VyZSBob3cgdGhlc2Ugd291bGQgYmUgdXNl ZCBpbiBwcmFjdGlzZS4gTXkgZ3V0IGlzIHRlbGxpbmcgbWUKU1VfUFNSIG1pZ2h0IGJlIHVzZWQg d2l0aCBsaW5rIHN0YW5kYnkgYW5kIERFRVBfUFNSIHdpdGggbGluayBvZmYsIGJ1dAp0aGF0J3Mg anVzdCBhIGh1bmNoIGF0IHRoaXMgcG9pbnQuCgpZb3UnbGwgc2VlIGluIGxhdGVyIHBhdGNoZXMg dGhhdCB3ZSdsbCBzdGFydCB1c2luZyB0aGUgb3ZlcnJpZGUgYml0cyB0bwpmb3JjZSB0aGUgcG93 ZXIgc3RhdGUsIHNvIEkgdGhpbmsgYXQgdGhhdCBwb2ludCB0aGVzZSBkb24ndCBldmVuIG1hdHRl ci4KQnV0IEkgc3VwcG9zZSB3aGVuIHdlIGVudGVyIFBTUiB3ZSBzaG91bGQgZHJvcCB0aGUgb3Zl cnJpZGUgYml0cyB0bwphbGxvdyB0aGUgaGFyZHdhcmUgdG8gbWFuYWdlIHRoZSBwb3dlciBzdGF0 ZXMgYmFzZWQgb24gdGhlIFBTUiBtb2RlCnNlbGVjdGVkLgoKPiAKPiBvdGhlciB0aGFuIHRoaXMs IHBhdGNoIGRvZXMgd2hhdCBpdCBzYXlzLgo+IFJldmlld2VkLWJ5OiAgRGVlcGFrIFM8ZGVlcGFr LnNAbGludXguaW50ZWwuY29tPgo+IAo+ID4gKyNkZWZpbmUgICBQSFlfQ0hfUE9XRVJfTU9ERSht b2RlLCBwaHksIGNoKQkoKG1vZGUpIDw8ICg2KihwaHkpKzMqKGNoKSsyKSkKPiA+ICsjZGVmaW5l ICAgUEhZX0NPTV9MQU5FX1JFU0VUX0RFQVNTRVJUKHBoeSkJKDEgPDwgKHBoeSkpCj4gPiAgICNk ZWZpbmUgRElTUExBWV9QSFlfU1RBVFVTIChWTFZfRElTUExBWV9CQVNFICsgMHg2MDEwNCkKPiA+ ICAgI2RlZmluZSAgIFBIWV9QT1dFUkdPT0QocGh5KQkoKChwaHkpID09IERQSU9fUEhZMCkgPyAo MTw8MzEpIDogKDE8PDMwKSkKPiA+ICAgCj4gPiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJt L2k5MTUvaW50ZWxfcnVudGltZV9wbS5jIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfcnVu dGltZV9wbS5jCj4gPiBpbmRleCBjZTAwZTY5Li5iNzM2NzFmIDEwMDY0NAo+ID4gLS0tIGEvZHJp dmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfcnVudGltZV9wbS5jCj4gPiArKysgYi9kcml2ZXJzL2dw dS9kcm0vaTkxNS9pbnRlbF9ydW50aW1lX3BtLmMKPiA+IEBAIC02NjYsOCArNjY2LDggQEAgc3Rh dGljIHZvaWQgY2h2X2RwaW9fY21uX3Bvd2VyX3dlbGxfZW5hYmxlKHN0cnVjdCBkcm1faTkxNV9w cml2YXRlICpkZXZfcHJpdiwKPiA+ICAgCWlmICh3YWl0X2ZvcihJOTE1X1JFQUQoRElTUExBWV9Q SFlfU1RBVFVTKSAmIFBIWV9QT1dFUkdPT0QocGh5KSwgMSkpCj4gPiAgIAkJRFJNX0VSUk9SKCJE aXNwbGF5IFBIWSAlZCBpcyBub3QgcG93ZXIgdXBcbiIsIHBoeSk7Cj4gPiAgIAo+ID4gLQlJOTE1 X1dSSVRFKERJU1BMQVlfUEhZX0NPTlRST0wsIEk5MTVfUkVBRChESVNQTEFZX1BIWV9DT05UUk9M KSB8Cj4gPiAtCQkgICBQSFlfQ09NX0xBTkVfUkVTRVRfREVBU1NFUlQocGh5KSk7Cj4gPiArCWRl dl9wcml2LT5jaHZfcGh5X2NvbnRyb2wgfD0gUEhZX0NPTV9MQU5FX1JFU0VUX0RFQVNTRVJUKHBo eSk7Cj4gPiArCUk5MTVfV1JJVEUoRElTUExBWV9QSFlfQ09OVFJPTCwgZGV2X3ByaXYtPmNodl9w aHlfY29udHJvbCk7Cj4gPiAgIH0KPiA+ICAgCj4gPiAgIHN0YXRpYyB2b2lkIGNodl9kcGlvX2Nt bl9wb3dlcl93ZWxsX2Rpc2FibGUoc3RydWN0IGRybV9pOTE1X3ByaXZhdGUgKmRldl9wcml2LAo+ ID4gQEAgLTY4Nyw4ICs2ODcsOCBAQCBzdGF0aWMgdm9pZCBjaHZfZHBpb19jbW5fcG93ZXJfd2Vs bF9kaXNhYmxlKHN0cnVjdCBkcm1faTkxNV9wcml2YXRlICpkZXZfcHJpdiwKPiA+ICAgCQlhc3Nl cnRfcGxsX2Rpc2FibGVkKGRldl9wcml2LCBQSVBFX0MpOwo+ID4gICAJfQo+ID4gICAKPiA+IC0J STkxNV9XUklURShESVNQTEFZX1BIWV9DT05UUk9MLCBJOTE1X1JFQUQoRElTUExBWV9QSFlfQ09O VFJPTCkgJgo+ID4gLQkJICAgflBIWV9DT01fTEFORV9SRVNFVF9ERUFTU0VSVChwaHkpKTsKPiA+ ICsJZGV2X3ByaXYtPmNodl9waHlfY29udHJvbCAmPSB+UEhZX0NPTV9MQU5FX1JFU0VUX0RFQVNT RVJUKHBoeSk7Cj4gPiArCUk5MTVfV1JJVEUoRElTUExBWV9QSFlfQ09OVFJPTCwgZGV2X3ByaXYt PmNodl9waHlfY29udHJvbCk7Cj4gPiAgIAo+ID4gICAJdmx2X3NldF9wb3dlcl93ZWxsKGRldl9w cml2LCBwb3dlcl93ZWxsLCBmYWxzZSk7Cj4gPiAgIH0KPiA+IEBAIC0xNDAxLDYgKzE0MDEsMzAg QEAgc3RhdGljIHZvaWQgaW50ZWxfcG93ZXJfZG9tYWluc19yZXN1bWUoc3RydWN0IGRybV9pOTE1 X3ByaXZhdGUgKmRldl9wcml2KQo+ID4gICAJbXV0ZXhfdW5sb2NrKCZwb3dlcl9kb21haW5zLT5s b2NrKTsKPiA+ICAgfQo+ID4gICAKPiA+ICtzdGF0aWMgdm9pZCBjaHZfcGh5X2NvbnRyb2xfaW5p dChzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqZGV2X3ByaXYpCj4gPiArewo+ID4gKwlzdHJ1Y3Qg aTkxNV9wb3dlcl93ZWxsICpjbW5fYmMgPQo+ID4gKwkJbG9va3VwX3Bvd2VyX3dlbGwoZGV2X3By aXYsIFBVTklUX1BPV0VSX1dFTExfRFBJT19DTU5fQkMpOwo+ID4gKwlzdHJ1Y3QgaTkxNV9wb3dl cl93ZWxsICpjbW5fZCA9Cj4gPiArCQlsb29rdXBfcG93ZXJfd2VsbChkZXZfcHJpdiwgUFVOSVRf UE9XRVJfV0VMTF9EUElPX0NNTl9EKTsKPiA+ICsKPiA+ICsJLyoKPiA+ICsJICogRElTUExBWV9Q SFlfQ09OVFJPTCBjYW4gZ2V0IGNvcnJ1cHRlZCBpZiByZWFkLiBBcyBhCj4gPiArCSAqIHdvcmth cm91bmQgbmV2ZXIgZXZlciByZWFkIERJU1BMQVlfUEhZX0NPTlRST0wsIGFuZAo+ID4gKwkgKiBp bnN0ZWFkIG1haW50YWluIGEgc2hhZG93IGNvcHkgb3Vyc2VsdmVzLiBVc2UgdGhlIGFjdHVhbAo+ ID4gKwkgKiBwb3dlciB3ZWxsIHN0YXRlIHRvIHJlY29uc3RydWN0IHRoZSBleHBlY3RlZCBpbml0 aWFsCj4gPiArCSAqIHZhbHVlLgo+ID4gKwkgKi8KPiA+ICsJZGV2X3ByaXYtPmNodl9waHlfY29u dHJvbCA9Cj4gPiArCQlQSFlfQ0hfUE9XRVJfTU9ERShQSFlfQ0hfU1VfUFNSLCBEUElPX1BIWTAs IERQSU9fQ0gwKSB8Cj4gPiArCQlQSFlfQ0hfUE9XRVJfTU9ERShQSFlfQ0hfU1VfUFNSLCBEUElP X1BIWTAsIERQSU9fQ0gxKSB8Cj4gPiArCQlQSFlfQ0hfUE9XRVJfTU9ERShQSFlfQ0hfU1VfUFNS LCBEUElPX1BIWTEsIERQSU9fQ0gwKTsKPiA+ICsJaWYgKGNtbl9iYy0+b3BzLT5pc19lbmFibGVk KGRldl9wcml2LCBjbW5fYmMpKQo+ID4gKwkJZGV2X3ByaXYtPmNodl9waHlfY29udHJvbCB8PSBQ SFlfQ09NX0xBTkVfUkVTRVRfREVBU1NFUlQoRFBJT19QSFkwKTsKPiA+ICsJaWYgKGNtbl9kLT5v cHMtPmlzX2VuYWJsZWQoZGV2X3ByaXYsIGNtbl9kKSkKPiA+ICsJCWRldl9wcml2LT5jaHZfcGh5 X2NvbnRyb2wgfD0gUEhZX0NPTV9MQU5FX1JFU0VUX0RFQVNTRVJUKERQSU9fUEhZMSk7Cj4gPiAr fQo+ID4gKwo+ID4gICBzdGF0aWMgdm9pZCB2bHZfY21ubGFuZV93YShzdHJ1Y3QgZHJtX2k5MTVf cHJpdmF0ZSAqZGV2X3ByaXYpCj4gPiAgIHsKPiA+ICAgCXN0cnVjdCBpOTE1X3Bvd2VyX3dlbGwg KmNtbiA9Cj4gPiBAQCAtMTQ0Myw3ICsxNDY3LDkgQEAgdm9pZCBpbnRlbF9wb3dlcl9kb21haW5z X2luaXRfaHcoc3RydWN0IGRybV9pOTE1X3ByaXZhdGUgKmRldl9wcml2KQo+ID4gICAKPiA+ICAg CXBvd2VyX2RvbWFpbnMtPmluaXRpYWxpemluZyA9IHRydWU7Cj4gPiAgIAo+ID4gLQlpZiAoSVNf VkFMTEVZVklFVyhkZXYpICYmICFJU19DSEVSUllWSUVXKGRldikpIHsKPiA+ICsJaWYgKElTX0NI RVJSWVZJRVcoZGV2KSkgewo+ID4gKwkJY2h2X3BoeV9jb250cm9sX2luaXQoZGV2X3ByaXYpOwo+ ID4gKwl9IGVsc2UgaWYgKElTX1ZBTExFWVZJRVcoZGV2KSkgewo+ID4gICAJCW11dGV4X2xvY2so JnBvd2VyX2RvbWFpbnMtPmxvY2spOwo+ID4gICAJCXZsdl9jbW5sYW5lX3dhKGRldl9wcml2KTsK PiA+ICAgCQltdXRleF91bmxvY2soJnBvd2VyX2RvbWFpbnMtPmxvY2spOwo+IAo+IF9fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCj4gSW50ZWwtZ2Z4IG1haWxp bmcgbGlzdAo+IEludGVsLWdmeEBsaXN0cy5mcmVlZGVza3RvcC5vcmcKPiBodHRwOi8vbGlzdHMu ZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vaW50ZWwtZ2Z4CgotLSAKVmlsbGUgU3ly asOkbMOkCkludGVsIE9UQwpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fXwpJbnRlbC1nZnggbWFpbGluZyBsaXN0CkludGVsLWdmeEBsaXN0cy5mcmVlZGVza3Rv cC5vcmcKaHR0cDovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2ludGVs LWdmeAo=