From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Conselvan De Oliveira, Ander" Subject: Re: [PATCH v2 07/10] drm/i915: Undiplicate VLV signal level code Date: Wed, 20 Apr 2016 05:23:05 +0000 Message-ID: <1461129783.2762.5.camel@intel.com> References: <1460569673-13694-1-git-send-email-ander.conselvan.de.oliveira@intel.com> <1460569673-13694-8-git-send-email-ander.conselvan.de.oliveira@intel.com> <20160419203726.GB2313@shiv> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mga02.intel.com (mga02.intel.com [134.134.136.20]) by gabe.freedesktop.org (Postfix) with ESMTP id 8BFB66E8E9 for ; Wed, 20 Apr 2016 05:23:08 +0000 (UTC) In-Reply-To: <20160419203726.GB2313@shiv> Content-Language: en-US Content-ID: <9D62790E580D684893405B6BC8A4FFB8@intel.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" To: "jim.bride@linux.intel.com" Cc: "intel-gfx@lists.freedesktop.org" List-Id: intel-gfx@lists.freedesktop.org T24gVHVlLCAyMDE2LTA0LTE5IGF0IDEzOjM3IC0wNzAwLCBKaW0gQnJpZGUgd3JvdGU6DQo+IE9u IFdlZCwgQXByIDEzLCAyMDE2IGF0IDA4OjQ3OjUwUE0gKzAzMDAsIEFuZGVyIENvbnNlbHZhbiBk ZSBPbGl2ZWlyYSB3cm90ZToNCj4gPiBUaGUgbG9naWMgZm9yIHNldHRpbmcgc2lnbmFsIGxldmVs cyBpcyB1c2VkIGZvciBib3RoIEhETUkgYW5kIERQIHdpdGgNCj4gPiBzbWFsbCB2YXJpYXRpb25z LiBCdXQgaXQgaXMgc2ltaWxhciBlbm91Z2ggdG8gcHV0IGJlaGluZCBhIGZ1bmN0aW9uDQo+ID4g Y2FsbGVkIGZyb20gdGhlIGVuY29kZXJzLg0KPiA+IA0KPiA+IFNpZ25lZC1vZmYtYnk6IEFuZGVy IENvbnNlbHZhbiBkZSBPbGl2ZWlyYSA8DQo+ID4gYW5kZXIuY29uc2VsdmFuLmRlLm9saXZlaXJh QGludGVsLmNvbT4NCj4gPiAtLS0NCj4gPiAgZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9kcnYu aCAgICAgICB8ICA0ICsrKysNCj4gPiAgZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfZHAuYyAg ICAgICB8IDQzICsrKysrKysrKysrKy0tLS0tLS0tLS0tLS0tLS0tLS0tDQo+ID4gLS0tDQo+ID4g IGRyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2RwaW9fcGh5LmMgfCAyNiArKysrKysrKysrKysr KysrKysrKysNCj4gPiAgZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfaGRtaS5jICAgICB8IDE0 ICsrKystLS0tLS0tLQ0KPiA+ICA0IGZpbGVzIGNoYW5nZWQsIDQ5IGluc2VydGlvbnMoKyksIDM4 IGRlbGV0aW9ucygtKQ0KPiA+IA0KPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vaTkx NS9pOTE1X2Rydi5oDQo+ID4gYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1X2Rydi5oDQo+ID4g aW5kZXggODVjMDYxMC4uZjI0ODFhMiAxMDA2NDQNCj4gPiAtLS0gYS9kcml2ZXJzL2dwdS9kcm0v aTkxNS9pOTE1X2Rydi5oDQo+ID4gKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9kcnYu aA0KPiA+IEBAIC0zNTY1LDYgKzM1NjUsMTAgQEAgdm9pZCBjaHZfcGh5X3ByZV9lbmNvZGVyX2Vu YWJsZShzdHJ1Y3QgaW50ZWxfZW5jb2Rlcg0KPiA+ICplbmNvZGVyKTsNCj4gPiAgdm9pZCBjaHZf cGh5X3JlbGVhc2VfY2wyX292ZXJyaWRlKHN0cnVjdCBpbnRlbF9lbmNvZGVyICplbmNvZGVyKTsN Cj4gPiAgdm9pZCBjaHZfcGh5X3Bvc3RfZGlzYWJsZShzdHJ1Y3QgaW50ZWxfZW5jb2RlciAqZW5j b2Rlcik7DQo+ID4gIA0KPiA+ICt2b2lkIHZsdl9zZXRfcGh5X3NpZ25hbF9sZXZlbChzdHJ1Y3Qg aW50ZWxfZW5jb2RlciAqZW5jb2RlciwNCj4gPiArCQkJICAgICAgdTMyIGRlbXBoX3JlZ192YWx1 ZSwgdTMyIHByZWVtcGhfcmVnX3ZhbHVlLA0KPiA+ICsJCQkgICAgICB1MzIgdW5pcXRyYW5zY2Fs ZV9yZWdfdmFsdWUsIHUzMiB0eDNfZGVtcGgpOw0KPiA+ICsNCj4gPiAgaW50IGludGVsX2dwdV9m cmVxKHN0cnVjdCBkcm1faTkxNV9wcml2YXRlICpkZXZfcHJpdiwgaW50IHZhbCk7DQo+ID4gIGlu dCBpbnRlbF9mcmVxX29wY29kZShzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqZGV2X3ByaXYsIGlu dCB2YWwpOw0KPiA+ICANCj4gPiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50 ZWxfZHAuYw0KPiA+IGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfZHAuYw0KPiA+IGluZGV4 IGNkYWNkOGIuLjNlNDIzNTUgMTAwNjQ0DQo+ID4gLS0tIGEvZHJpdmVycy9ncHUvZHJtL2k5MTUv aW50ZWxfZHAuYw0KPiA+ICsrKyBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2RwLmMNCj4g PiBAQCAtMzAwOSwxNiArMzAwOSwxMCBAQCBpbnRlbF9kcF9wcmVfZW1waGFzaXNfbWF4KHN0cnVj dCBpbnRlbF9kcCAqaW50ZWxfZHAsDQo+ID4gdWludDhfdCB2b2x0YWdlX3N3aW5nKQ0KPiA+ICAN Cj4gPiAgc3RhdGljIHVpbnQzMl90IHZsdl9zaWduYWxfbGV2ZWxzKHN0cnVjdCBpbnRlbF9kcCAq aW50ZWxfZHApDQo+ID4gIHsNCj4gPiAtCXN0cnVjdCBkcm1fZGV2aWNlICpkZXYgPSBpbnRlbF9k cF90b19kZXYoaW50ZWxfZHApOw0KPiA+IC0Jc3RydWN0IGRybV9pOTE1X3ByaXZhdGUgKmRldl9w cml2ID0gZGV2LT5kZXZfcHJpdmF0ZTsNCj4gPiAtCXN0cnVjdCBpbnRlbF9kaWdpdGFsX3BvcnQg KmRwb3J0ID0gZHBfdG9fZGlnX3BvcnQoaW50ZWxfZHApOw0KPiA+IC0Jc3RydWN0IGludGVsX2Ny dGMgKmludGVsX2NydGMgPQ0KPiA+IC0JCXRvX2ludGVsX2NydGMoZHBvcnQtPmJhc2UuYmFzZS5j cnRjKTsNCj4gPiArCXN0cnVjdCBpbnRlbF9lbmNvZGVyICplbmNvZGVyID0gJmRwX3RvX2RpZ19w b3J0KGludGVsX2RwKS0+YmFzZTsNCj4gPiAgCXVuc2lnbmVkIGxvbmcgZGVtcGhfcmVnX3ZhbHVl LCBwcmVlbXBoX3JlZ192YWx1ZSwNCj4gPiAgCQl1bmlxdHJhbnNjYWxlX3JlZ192YWx1ZTsNCj4g PiAgCXVpbnQ4X3QgdHJhaW5fc2V0ID0gaW50ZWxfZHAtPnRyYWluX3NldFswXTsNCj4gPiAtCWVu dW0gZHBpb19jaGFubmVsIHBvcnQgPSB2bHZfZHBvcnRfdG9fY2hhbm5lbChkcG9ydCk7DQo+ID4g LQlpbnQgcGlwZSA9IGludGVsX2NydGMtPnBpcGU7DQo+ID4gIA0KPiA+ICAJc3dpdGNoICh0cmFp bl9zZXQgJiBEUF9UUkFJTl9QUkVfRU1QSEFTSVNfTUFTSykgew0KPiA+ICAJY2FzZSBEUF9UUkFJ Tl9QUkVfRU1QSF9MRVZFTF8wOg0KPiA+IEBAIC0zMDkzLDE2ICszMDg3LDggQEAgc3RhdGljIHVp bnQzMl90IHZsdl9zaWduYWxfbGV2ZWxzKHN0cnVjdCBpbnRlbF9kcA0KPiA+ICppbnRlbF9kcCkN Cj4gPiAgCQlyZXR1cm4gMDsNCj4gPiAgCX0NCj4gPiAgDQo+ID4gLQltdXRleF9sb2NrKCZkZXZf cHJpdi0+c2JfbG9jayk7DQo+ID4gLQl2bHZfZHBpb193cml0ZShkZXZfcHJpdiwgcGlwZSwgVkxW X1RYX0RXNShwb3J0KSwgMHgwMDAwMDAwMCk7DQo+ID4gLQl2bHZfZHBpb193cml0ZShkZXZfcHJp diwgcGlwZSwgVkxWX1RYX0RXNChwb3J0KSwgZGVtcGhfcmVnX3ZhbHVlKTsNCj4gPiAtCXZsdl9k cGlvX3dyaXRlKGRldl9wcml2LCBwaXBlLCBWTFZfVFhfRFcyKHBvcnQpLA0KPiA+IC0JCQkgdW5p cXRyYW5zY2FsZV9yZWdfdmFsdWUpOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBp cGUsIFZMVl9UWF9EVzMocG9ydCksIDB4MEM3ODIwNDApOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUo ZGV2X3ByaXYsIHBpcGUsIFZMVl9QQ1NfRFcxMShwb3J0KSwgMHgwMDAzMDAwMCk7DQo+ID4gLQl2 bHZfZHBpb193cml0ZShkZXZfcHJpdiwgcGlwZSwgVkxWX1BDU19EVzkocG9ydCksDQo+ID4gcHJl ZW1waF9yZWdfdmFsdWUpOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZM Vl9UWF9EVzUocG9ydCksIDB4ODAwMDAwMDApOw0KPiA+IC0JbXV0ZXhfdW5sb2NrKCZkZXZfcHJp di0+c2JfbG9jayk7DQo+ID4gKwl2bHZfc2V0X3BoeV9zaWduYWxfbGV2ZWwoZW5jb2RlciwgZGVt cGhfcmVnX3ZhbHVlLA0KPiA+IHByZWVtcGhfcmVnX3ZhbHVlLA0KPiA+ICsJCQkJIHVuaXF0cmFu c2NhbGVfcmVnX3ZhbHVlLCAwKTsNCj4gPiAgDQo+ID4gIAlyZXR1cm4gMDsNCj4gPiAgfQ0KPiA+ IEBAIC00Mjg1LDE3ICs0MjcxLDYgQEAgaW50ZWxfZHBfbG9uZ19wdWxzZShzdHJ1Y3QgaW50ZWxf Y29ubmVjdG9yDQo+ID4gKmludGVsX2Nvbm5lY3RvcikNCj4gPiAgCQlpbnRlbF9kcC0+Y29tcGxp YW5jZV90ZXN0X3R5cGUgPSAwOw0KPiA+ICAJCWludGVsX2RwLT5jb21wbGlhbmNlX3Rlc3RfZGF0 YSA9IDA7DQo+ID4gIA0KPiA+IC0JCS8qDQo+ID4gLQkJICogSWYgd2Ugd2VyZSBpbiBNU1QgbW9k ZSwgYW5kIGRldmljZSBpcyBub3QgdGhlcmUsDQo+ID4gLQkJICogZ2V0IG91dCBvZiBNU1QgbW9k ZQ0KPiA+IC0JCSAqLw0KPiA+IC0JCWlmIChpbnRlbF9kcC0+aXNfbXN0KSB7DQo+ID4gLQkJCURS TV9ERUJVR19LTVMoIk1TVCBkZXZpY2UgbWF5IGhhdmUgZGlzYXBwZWFyZWQgJWQNCj4gPiB2cyAl ZFxuIiwNCj4gPiAtCQkJCSAgICAgIGludGVsX2RwLT5pc19tc3QsIGludGVsX2RwDQo+ID4gLT5t c3RfbWdyLm1zdF9zdGF0ZSk7DQo+ID4gLQkJCWludGVsX2RwLT5pc19tc3QgPSBmYWxzZTsNCj4g PiAtCQkJZHJtX2RwX21zdF90b3BvbG9neV9tZ3Jfc2V0X21zdCgmaW50ZWxfZHAtPm1zdF9tZ3Is DQo+ID4gLQkJCQkJCQlpbnRlbF9kcC0+aXNfbXN0KTsNCj4gPiAtCQl9DQo+ID4gIAkJZ290byBv dXQ7DQo+ID4gIAl9DQo+ID4gIA0KPiA+IEBAIC00MzU1LDYgKzQzMzAsMTggQEAgaW50ZWxfZHBf bG9uZ19wdWxzZShzdHJ1Y3QgaW50ZWxfY29ubmVjdG9yDQo+ID4gKmludGVsX2Nvbm5lY3RvcikN Cj4gPiAgb3V0Og0KPiA+ICAJaWYgKHN0YXR1cyAhPSBjb25uZWN0b3Jfc3RhdHVzX2Nvbm5lY3Rl ZCkgew0KPiA+ICAJCWludGVsX2RwX3Vuc2V0X2VkaWQoaW50ZWxfZHApOw0KPiA+ICsNCj4gPiAr CQkvKg0KPiA+ICsJCSAqIElmIHdlIHdlcmUgaW4gTVNUIG1vZGUsIGFuZCBkZXZpY2UgaXMgbm90 IHRoZXJlLA0KPiA+ICsJCSAqIGdldCBvdXQgb2YgTVNUIG1vZGUNCj4gPiArCQkgKi8NCj4gPiAr CQlpZiAoaW50ZWxfZHAtPmlzX21zdCkgew0KPiA+ICsJCQlEUk1fREVCVUdfS01TKCJNU1QgZGV2 aWNlIG1heSBoYXZlIGRpc2FwcGVhcmVkICVkDQo+ID4gdnMgJWRcbiIsDQo+ID4gKwkJCQkgICAg ICBpbnRlbF9kcC0+aXNfbXN0LCBpbnRlbF9kcA0KPiA+IC0+bXN0X21nci5tc3Rfc3RhdGUpOw0K PiA+ICsJCQlpbnRlbF9kcC0+aXNfbXN0ID0gZmFsc2U7DQo+ID4gKwkJCWRybV9kcF9tc3RfdG9w b2xvZ3lfbWdyX3NldF9tc3QoJmludGVsX2RwLT5tc3RfbWdyLA0KPiA+ICsJCQkJCQkJaW50ZWxf ZHAtPmlzX21zdCk7DQo+ID4gKwkJfQ0KPiANCj4gVGhlIHR3byBodW5rcyBhYm92ZSBzZWVtIHVu cmVsYXRlZCB0byB3aGF0IHRoZSBwYXRjaCBzZXQgaXMgdHJ5aW5nIHRvIGRvIGFuZA0KPiB3b3Vs ZCBicmVhayBEUCBNU1QgYWdhaW4uIDspDQoNCkkgbWl4ZWQgdGhpbmdzIHVwIHdoZW4gcmViYXNp bmcgb24gdG9wIG9mIHlvdXIgY2hhbmdlcy4gSSByZW1lbWJlciBmaXhpbmcgdGhhdCwNCmJ1dCBh bGFzLCBJIGRpZG4ndC4gDQoNCkFuZGVyDQoNCg0KPiANCj4gSmltDQo+IA0KPiANCj4gPiAgCX0N Cj4gPiAgDQo+ID4gIAlpbnRlbF9kaXNwbGF5X3Bvd2VyX3B1dCh0b19pOTE1KGRldiksIHBvd2Vy X2RvbWFpbik7DQo+ID4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2Rw aW9fcGh5LmMNCj4gPiBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2RwaW9fcGh5LmMNCj4g PiBpbmRleCAyNDAwNTU0Li5kOWU2NDgyIDEwMDY0NA0KPiA+IC0tLSBhL2RyaXZlcnMvZ3B1L2Ry bS9pOTE1L2ludGVsX2RwaW9fcGh5LmMNCj4gPiArKysgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9p bnRlbF9kcGlvX3BoeS5jDQo+ID4gQEAgLTM2OSwzICszNjksMjkgQEAgdm9pZCBjaHZfcGh5X3Bv c3RfZGlzYWJsZShzdHJ1Y3QgaW50ZWxfZW5jb2Rlcg0KPiA+ICplbmNvZGVyKQ0KPiA+ICAJICov DQo+ID4gIAljaHZfcGh5X3Bvd2VyZ2F0ZV9sYW5lcyhlbmNvZGVyLCBmYWxzZSwgMHgwKTsNCj4g PiAgfQ0KPiA+ICsNCj4gPiArdm9pZCB2bHZfc2V0X3BoeV9zaWduYWxfbGV2ZWwoc3RydWN0IGlu dGVsX2VuY29kZXIgKmVuY29kZXIsDQo+ID4gKwkJCSAgICAgIHUzMiBkZW1waF9yZWdfdmFsdWUs IHUzMiBwcmVlbXBoX3JlZ192YWx1ZSwNCj4gPiArCQkJICAgICAgdTMyIHVuaXF0cmFuc2NhbGVf cmVnX3ZhbHVlLCB1MzIgdHgzX2RlbXBoKQ0KPiA+ICt7DQo+ID4gKwlzdHJ1Y3QgZHJtX2k5MTVf cHJpdmF0ZSAqZGV2X3ByaXYgPSB0b19pOTE1KGVuY29kZXItPmJhc2UuZGV2KTsNCj4gPiArCXN0 cnVjdCBpbnRlbF9jcnRjICppbnRlbF9jcnRjID0gdG9faW50ZWxfY3J0YyhlbmNvZGVyLT5iYXNl LmNydGMpOw0KPiA+ICsJc3RydWN0IGludGVsX2RpZ2l0YWxfcG9ydCAqZHBvcnQgPSBlbmNfdG9f ZGlnX3BvcnQoJmVuY29kZXItPmJhc2UpOw0KPiA+ICsJZW51bSBkcGlvX2NoYW5uZWwgcG9ydCA9 IHZsdl9kcG9ydF90b19jaGFubmVsKGRwb3J0KTsNCj4gPiArCWludCBwaXBlID0gaW50ZWxfY3J0 Yy0+cGlwZTsNCj4gPiArDQo+ID4gKwltdXRleF9sb2NrKCZkZXZfcHJpdi0+c2JfbG9jayk7DQo+ ID4gKwl2bHZfZHBpb193cml0ZShkZXZfcHJpdiwgcGlwZSwgVkxWX1RYX0RXNShwb3J0KSwgMHgw MDAwMDAwMCk7DQo+ID4gKwl2bHZfZHBpb193cml0ZShkZXZfcHJpdiwgcGlwZSwgVkxWX1RYX0RX NChwb3J0KSwgZGVtcGhfcmVnX3ZhbHVlKTsNCj4gPiArCXZsdl9kcGlvX3dyaXRlKGRldl9wcml2 LCBwaXBlLCBWTFZfVFhfRFcyKHBvcnQpLA0KPiA+ICsJCQkgdW5pcXRyYW5zY2FsZV9yZWdfdmFs dWUpOw0KPiA+ICsJdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9UWF9EVzMocG9y dCksIDB4MEM3ODIwNDApOw0KPiA+ICsNCj4gPiArCWlmICh0eDNfZGVtcGgpDQo+ID4gKwkJdmx2 X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9UWDNfRFc0KHBvcnQpLA0KPiA+IHR4M19k ZW1waCk7DQo+ID4gKw0KPiA+ICsJdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9Q Q1NfRFcxMShwb3J0KSwgMHgwMDAzMDAwMCk7DQo+ID4gKwl2bHZfZHBpb193cml0ZShkZXZfcHJp diwgcGlwZSwgVkxWX1BDU19EVzkocG9ydCksDQo+ID4gcHJlZW1waF9yZWdfdmFsdWUpOw0KPiA+ ICsJdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9UWF9EVzUocG9ydCksDQo+ID4g RFBJT19UWF9PQ0FMSU5JVF9FTik7DQo+ID4gKwltdXRleF91bmxvY2soJmRldl9wcml2LT5zYl9s b2NrKTsNCj4gPiArfQ0KPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pbnRl bF9oZG1pLmMNCj4gPiBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2hkbWkuYw0KPiA+IGlu ZGV4IGY0MjRhZjUuLjkzODY3NzIgMTAwNjQ0DQo+ID4gLS0tIGEvZHJpdmVycy9ncHUvZHJtL2k5 MTUvaW50ZWxfaGRtaS5jDQo+ID4gKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfaGRt aS5jDQo+ID4gQEAgLTE2MDEsMjEgKzE2MDEsMTUgQEAgc3RhdGljIHZvaWQgdmx2X2hkbWlfcHJl X2VuYWJsZShzdHJ1Y3QgaW50ZWxfZW5jb2Rlcg0KPiA+ICplbmNvZGVyKQ0KPiA+ICAJdmFsIHw9 IDB4MDAxMDAwYzQ7DQo+ID4gIAl2bHZfZHBpb193cml0ZShkZXZfcHJpdiwgcGlwZSwgVkxWX1BD U19EVzgocG9ydCksIHZhbCk7DQo+ID4gIA0KPiA+IC0JLyogSERNSSAxLjBWLTJkQiAqLw0KPiA+ IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9UWF9EVzUocG9ydCksIDApOw0K PiA+IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9UWF9EVzQocG9ydCksIDB4 MmIyNDVmNWYpOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9UWF9E VzIocG9ydCksIDB4NTU3OGI4M2EpOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBp cGUsIFZMVl9UWF9EVzMocG9ydCksIDB4MGM3ODIwNDApOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUo ZGV2X3ByaXYsIHBpcGUsIFZMVl9UWDNfRFc0KHBvcnQpLCAweDJiMjQ3ODc4KTsNCj4gPiAtCXZs dl9kcGlvX3dyaXRlKGRldl9wcml2LCBwaXBlLCBWTFZfUENTX0RXMTEocG9ydCksIDB4MDAwMzAw MDApOw0KPiA+IC0Jdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYsIHBpcGUsIFZMVl9QQ1NfRFc5KHBv cnQpLCAweDAwMDAyMDAwKTsNCj4gPiAtCXZsdl9kcGlvX3dyaXRlKGRldl9wcml2LCBwaXBlLCBW TFZfVFhfRFc1KHBvcnQpLA0KPiA+IERQSU9fVFhfT0NBTElOSVRfRU4pOw0KPiA+IC0NCj4gPiAg CS8qIFByb2dyYW0gbGFuZSBjbG9jayAqLw0KPiA+ICAJdmx2X2RwaW9fd3JpdGUoZGV2X3ByaXYs IHBpcGUsIFZMVl9QQ1NfRFcxNChwb3J0KSwgMHgwMDc2MDAxOCk7DQo+ID4gIAl2bHZfZHBpb193 cml0ZShkZXZfcHJpdiwgcGlwZSwgVkxWX1BDU19EVzIzKHBvcnQpLCAweDAwNDAwODg4KTsNCj4g PiAgCW11dGV4X3VubG9jaygmZGV2X3ByaXYtPnNiX2xvY2spOw0KPiA+ICANCj4gPiArCS8qIEhE TUkgMS4wVi0yZEIgKi8NCj4gPiArCXZsdl9zZXRfcGh5X3NpZ25hbF9sZXZlbChlbmNvZGVyLCAw eDJiMjQ1ZjVmLCAweDAwMDAyMDAwLA0KPiA+IDB4NTU3OGI4M2EsDQo+ID4gKwkJCQkgMHgyYjI0 Nzg3OCk7DQo+ID4gKw0KPiA+ICAJaW50ZWxfaGRtaS0+c2V0X2luZm9mcmFtZXMoJmVuY29kZXIt PmJhc2UsDQo+ID4gIAkJCQkgICBpbnRlbF9jcnRjLT5jb25maWctPmhhc19oZG1pX3NpbmssDQo+ ID4gIAkJCQkgICBhZGp1c3RlZF9tb2RlKTsKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCkludGVsIEZpbmxhbmQgT3kK UmVnaXN0ZXJlZCBBZGRyZXNzOiBQTCAyODEsIDAwMTgxIEhlbHNpbmtpIApCdXNpbmVzcyBJZGVu dGl0eSBDb2RlOiAwMzU3NjA2IC0gNCAKRG9taWNpbGVkIGluIEhlbHNpbmtpIAoKVGhpcyBlLW1h aWwgYW5kIGFueSBhdHRhY2htZW50cyBtYXkgY29udGFpbiBjb25maWRlbnRpYWwgbWF0ZXJpYWwg Zm9yCnRoZSBzb2xlIHVzZSBvZiB0aGUgaW50ZW5kZWQgcmVjaXBpZW50KHMpLiBBbnkgcmV2aWV3 IG9yIGRpc3RyaWJ1dGlvbgpieSBvdGhlcnMgaXMgc3RyaWN0bHkgcHJvaGliaXRlZC4gSWYgeW91 IGFyZSBub3QgdGhlIGludGVuZGVkCnJlY2lwaWVudCwgcGxlYXNlIGNvbnRhY3QgdGhlIHNlbmRl ciBhbmQgZGVsZXRlIGFsbCBjb3BpZXMuCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fCkludGVsLWdmeCBtYWlsaW5nIGxpc3QKSW50ZWwtZ2Z4QGxpc3RzLmZy ZWVkZXNrdG9wLm9yZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3Rp bmZvL2ludGVsLWdmeAo=