From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ayan Kumar Halder Subject: [PATCH v2 3/4] drm/arm/malidp: Set the AFBC register bits if the framebuffer has AFBC modifier Date: Tue, 10 Jul 2018 14:18:56 +0100 Message-ID: <1531228737-5450-4-git-send-email-ayan.halder@arm.com> References: <1531228737-5450-1-git-send-email-ayan.halder@arm.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from EUR03-DB5-obe.outbound.protection.outlook.com (mail-eopbgr40051.outbound.protection.outlook.com [40.107.4.51]) by gabe.freedesktop.org (Postfix) with ESMTPS id 72AA76E743 for ; Tue, 10 Jul 2018 13:19:29 +0000 (UTC) In-Reply-To: <1531228737-5450-1-git-send-email-ayan.halder@arm.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: ayan.halder@arm.com, liviu.dudau@arm.com, brian.starkey@arm.com, malidp@foss.arm.com, airlied@linux.ie, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Cc: nd@arm.com List-Id: dri-devel@lists.freedesktop.org QWRkZWQgdGhlIEFGQkMgZGVjb2RlciByZWdpc3RlcnMgZm9yIERQNTAwICwgRFA1NTAgYW5kIERQ NjUwLgpUaGVzZSByZWdpc3RlcnMgY29udHJvbCB0aGUgcHJvY2Vzc2luZyBvZiBBRkJDIGJ1ZmZl cnMuIEl0IGNvbnRyb2xzIHZhcmlvdXMKZmVhdHVyZXMgbGlrZSBBRkJDIGRlY29kZXIgZW5hYmxl LCBsb3NzbGVzcyB0cmFuc2Zvcm1hdGlvbiBhbmQgYmxvY2sgc3BsaXQKYXMgd2VsbCBhcyBzZXR0 aW5nIG9mIHRoZSBsZWZ0LCByaWdodCwgdG9wIGFuZCBib3R0b20gY3JvcHBpbmcgb2YgQUZCQyBi dWZmZXJzCihpbiBudW1iZXIgb2YgcGl4ZWxzKS4KQWxsIHRoZSBsYXllcnMgKGV4Y2VwdCBERV9T TUFSVCkgc3VwcG9ydCBmcmFtZWJ1ZmZlcnMgd2l0aCBBRkJDIG1vZGlmaWVycy4KT25lIG5lZWRz IHRvIHNldCB0aGUgcGl4ZWwgdmFsdWVzIG9mIHRoZSB0b3AsIGxlZnQsIGJvdHRvbSBhbmQgcmln aHQgY3JvcHBpbmcKZm9yIHRoZSBBRkJDIGZyYW1lYnVmZmVyLgpBZGRlZCB0aGUgZnVuY3Rpb25h bGl0eSBpbiBtYWxpZHBfZGVfcGxhbmVfdXBkYXRlKCkgdG8gc2V0IHRoZSB2YXJpb3VzCnJlZ2lz dGVycyBmb3IgQUZCQyBkZWNvZGVyLCBkZXBlbmRpbmcgb24gdGhlIG1vZGlmaWVycy4KCkNoYW5n ZXMgZnJvbSB2MjotCi0gUmVtb3ZlZCB0aGUgImlmIChmYi0+bW9kaWZpZXIpIiBjaGVjayBmcm9t IG1hbGlkcF9kZV9wbGFuZV91cGRhdGUoKQphbmQgYWRkZWQgaXQgaW4gbWFsaWRwX2RlX3NldF9w bGFuZV9hZmJjKCkuIFRoaXMgd2lsbCBjb25zb2xpZGF0ZSBhbGwgdGhlCkFGQkMgc3BlY2lmaWMg cmVnaXN0ZXIgY29uZmlndXJhdGlvbnMgaW4gYSBzaW5nbGUgZnVuY3Rpb24gaWUKbWFsaWRwX2Rl X3NldF9wbGFuZV9hZmJjKCkuCgpTaWduZWQtb2ZmLWJ5OiBBeWFuIEt1bWFyIGhhbGRlciA8YXlh bi5oYWxkZXJAYXJtLmNvbT4KUmV2aWV3ZWQtYnk6IEJyaWFuIFN0YXJrZXkgPGJyaWFuLnN0YXJr ZXlAYXJtLmNvbT4KLS0tCiBkcml2ZXJzL2dwdS9kcm0vYXJtL21hbGlkcF9ody5jICAgICB8IDI3 ICsrKysrKystLS0tLQogZHJpdmVycy9ncHUvZHJtL2FybS9tYWxpZHBfaHcuaCAgICAgfCAgMiAr CiBkcml2ZXJzL2dwdS9kcm0vYXJtL21hbGlkcF9wbGFuZXMuYyB8IDgzICsrKysrKysrKysrKysr KysrKysrKysrKysrKysrKysrKy0tLS0KIGRyaXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX3JlZ3Mu aCAgIHwgMjAgKysrKysrKysrCiA0IGZpbGVzIGNoYW5nZWQsIDExMyBpbnNlcnRpb25zKCspLCAx OSBkZWxldGlvbnMoLSkKCmRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vYXJtL21hbGlkcF9o dy5jIGIvZHJpdmVycy9ncHUvZHJtL2FybS9tYWxpZHBfaHcuYwppbmRleCA0ZGJmMzlmLi5mZDZi NTEwIDEwMDY0NAotLS0gYS9kcml2ZXJzL2dwdS9kcm0vYXJtL21hbGlkcF9ody5jCisrKyBiL2Ry aXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX2h3LmMKQEAgLTc2LDMzICs3NiwzOCBAQCBzdGF0aWMg Y29uc3Qgc3RydWN0IG1hbGlkcF9mb3JtYXRfaWQgbWFsaWRwNTUwX2RlX2Zvcm1hdHNbXSA9IHsK IAogc3RhdGljIGNvbnN0IHN0cnVjdCBtYWxpZHBfbGF5ZXIgbWFsaWRwNTAwX2xheWVyc1tdID0g ewogCXsgREVfVklERU8xLCBNQUxJRFA1MDBfREVfTFZfQkFTRSwgTUFMSURQNTAwX0RFX0xWX1BU Ul9CQVNFLAotCQlNQUxJRFBfREVfTFZfU1RSSURFMCwgTUFMSURQNTAwX0xWX1lVVjJSR0IsIFJP VEFURV9BTlkgfSwKKwkJTUFMSURQX0RFX0xWX1NUUklERTAsIE1BTElEUDUwMF9MVl9ZVVYyUkdC LCBST1RBVEVfQU5ZLAorCQlNQUxJRFA1MDBfREVfTFZfQURfQ1RSTCB9LAogCXsgREVfR1JBUEhJ Q1MxLCBNQUxJRFA1MDBfREVfTEcxX0JBU0UsIE1BTElEUDUwMF9ERV9MRzFfUFRSX0JBU0UsCi0J CU1BTElEUF9ERV9MR19TVFJJREUsIDAsIFJPVEFURV9BTlkgfSwKKwkJTUFMSURQX0RFX0xHX1NU UklERSwgMCwgUk9UQVRFX0FOWSwgTUFMSURQNTAwX0RFX0xHMV9BRF9DVFJMIH0sCiAJeyBERV9H UkFQSElDUzIsIE1BTElEUDUwMF9ERV9MRzJfQkFTRSwgTUFMSURQNTAwX0RFX0xHMl9QVFJfQkFT RSwKLQkJTUFMSURQX0RFX0xHX1NUUklERSwgMCwgUk9UQVRFX0FOWSB9LAorCQlNQUxJRFBfREVf TEdfU1RSSURFLCAwLCBST1RBVEVfQU5ZLCBNQUxJRFA1MDBfREVfTEcyX0FEX0NUUkwgfSwKIH07 CiAKIHN0YXRpYyBjb25zdCBzdHJ1Y3QgbWFsaWRwX2xheWVyIG1hbGlkcDU1MF9sYXllcnNbXSA9 IHsKIAl7IERFX1ZJREVPMSwgTUFMSURQNTUwX0RFX0xWMV9CQVNFLCBNQUxJRFA1NTBfREVfTFYx X1BUUl9CQVNFLAotCQlNQUxJRFBfREVfTFZfU1RSSURFMCwgTUFMSURQNTUwX0xWX1lVVjJSR0Is IFJPVEFURV9BTlkgfSwKKwkJTUFMSURQX0RFX0xWX1NUUklERTAsIE1BTElEUDU1MF9MVl9ZVVYy UkdCLCBST1RBVEVfQU5ZLAorCQlNQUxJRFA1NTBfREVfTFYxX0FEX0NUUkwgfSwKIAl7IERFX0dS QVBISUNTMSwgTUFMSURQNTUwX0RFX0xHX0JBU0UsIE1BTElEUDU1MF9ERV9MR19QVFJfQkFTRSwK LQkJTUFMSURQX0RFX0xHX1NUUklERSwgMCwgUk9UQVRFX0FOWSB9LAorCQlNQUxJRFBfREVfTEdf U1RSSURFLCAwLCBST1RBVEVfQU5ZLCBNQUxJRFA1NTBfREVfTEdfQURfQ1RSTCB9LAogCXsgREVf VklERU8yLCBNQUxJRFA1NTBfREVfTFYyX0JBU0UsIE1BTElEUDU1MF9ERV9MVjJfUFRSX0JBU0Us Ci0JCU1BTElEUF9ERV9MVl9TVFJJREUwLCBNQUxJRFA1NTBfTFZfWVVWMlJHQiwgUk9UQVRFX0FO WSB9LAorCQlNQUxJRFBfREVfTFZfU1RSSURFMCwgTUFMSURQNTUwX0xWX1lVVjJSR0IsIFJPVEFU RV9BTlksCisJCU1BTElEUDU1MF9ERV9MVjJfQURfQ1RSTCB9LAogCXsgREVfU01BUlQsIE1BTElE UDU1MF9ERV9MU19CQVNFLCBNQUxJRFA1NTBfREVfTFNfUFRSX0JBU0UsCi0JCU1BTElEUDU1MF9E RV9MU19SMV9TVFJJREUsIDAsIFJPVEFURV9OT05FIH0sCisJCU1BTElEUDU1MF9ERV9MU19SMV9T VFJJREUsIDAsIFJPVEFURV9OT05FLCAwIH0sCiB9OwogCiBzdGF0aWMgY29uc3Qgc3RydWN0IG1h bGlkcF9sYXllciBtYWxpZHA2NTBfbGF5ZXJzW10gPSB7CiAJeyBERV9WSURFTzEsIE1BTElEUDU1 MF9ERV9MVjFfQkFTRSwgTUFMSURQNTUwX0RFX0xWMV9QVFJfQkFTRSwKLQkJTUFMSURQX0RFX0xW X1NUUklERTAsIE1BTElEUDU1MF9MVl9ZVVYyUkdCLCBST1RBVEVfQU5ZIH0sCisJCU1BTElEUF9E RV9MVl9TVFJJREUwLCBNQUxJRFA1NTBfTFZfWVVWMlJHQiwgUk9UQVRFX0FOWSwKKwkJTUFMSURQ NTUwX0RFX0xWMV9BRF9DVFJMIH0sCiAJeyBERV9HUkFQSElDUzEsIE1BTElEUDU1MF9ERV9MR19C QVNFLCBNQUxJRFA1NTBfREVfTEdfUFRSX0JBU0UsCi0JCU1BTElEUF9ERV9MR19TVFJJREUsIDAs IFJPVEFURV9DT01QUkVTU0VEIH0sCisJCU1BTElEUF9ERV9MR19TVFJJREUsIDAsIFJPVEFURV9D T01QUkVTU0VELCBNQUxJRFA1NTBfREVfTEdfQURfQ1RSTCB9LAogCXsgREVfVklERU8yLCBNQUxJ RFA1NTBfREVfTFYyX0JBU0UsIE1BTElEUDU1MF9ERV9MVjJfUFRSX0JBU0UsCi0JCU1BTElEUF9E RV9MVl9TVFJJREUwLCBNQUxJRFA1NTBfTFZfWVVWMlJHQiwgUk9UQVRFX0FOWSB9LAorCQlNQUxJ RFBfREVfTFZfU1RSSURFMCwgTUFMSURQNTUwX0xWX1lVVjJSR0IsIFJPVEFURV9BTlksCisJCU1B TElEUDU1MF9ERV9MVjJfQURfQ1RSTCB9LAogCXsgREVfU01BUlQsIE1BTElEUDU1MF9ERV9MU19C QVNFLCBNQUxJRFA1NTBfREVfTFNfUFRSX0JBU0UsCi0JCU1BTElEUDU1MF9ERV9MU19SMV9TVFJJ REUsIDAsIFJPVEFURV9OT05FIH0sCisJCU1BTElEUDU1MF9ERV9MU19SMV9TVFJJREUsIDAsIFJP VEFURV9OT05FLCAwIH0sCiB9OwogCiAjZGVmaW5lIFNFX05fU0NBTElOR19DT0VGRlMJOTYKZGlm ZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX2h3LmggYi9kcml2ZXJzL2dwdS9k cm0vYXJtL21hbGlkcF9ody5oCmluZGV4IDQzOTAyNDMuLmJiZTY4ODMgMTAwNjQ0Ci0tLSBhL2Ry aXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX2h3LmgKKysrIGIvZHJpdmVycy9ncHUvZHJtL2FybS9t YWxpZHBfaHcuaApAQCAtNjcsNiArNjcsOCBAQCBzdHJ1Y3QgbWFsaWRwX2xheWVyIHsKIAl1MTYg c3RyaWRlX29mZnNldDsJLyogb2Zmc2V0IHRvIHRoZSBmaXJzdCBzdHJpZGUgcmVnaXN0ZXIuICov CiAJczE2IHl1djJyZ2Jfb2Zmc2V0OwkvKiBvZmZzZXQgdG8gdGhlIFlVVi0+UkdCIG1hdHJpeCBl bnRyaWVzICovCiAJZW51bSByb3RhdGlvbl9mZWF0dXJlcyByb3Q7ICAgIC8qIHR5cGUgb2Ygcm90 YXRpb24gc3VwcG9ydGVkICovCisJLyogYWRkcmVzcyBvZmZzZXQgZm9yIHRoZSBBRkJDIGRlY29k ZXIgcmVnaXN0ZXJzICovCisJdTE2IGFmYmNfZGVjb2Rlcl9vZmZzZXQ7CiB9OwogCiBlbnVtIG1h bGlkcF9zY2FsaW5nX2NvZWZmX3NldCB7CmRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vYXJt L21hbGlkcF9wbGFuZXMuYyBiL2RyaXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX3BsYW5lcy5jCmlu ZGV4IDUzM2NkZGUuLjAxMjIwOTEgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9hcm0vbWFs aWRwX3BsYW5lcy5jCisrKyBiL2RyaXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX3BsYW5lcy5jCkBA IC0zMzAsNiArMzMwLDc2IEBAIHN0YXRpYyB2b2lkIG1hbGlkcF9kZV9zZXRfY29sb3JfZW5jb2Rp bmcoc3RydWN0IG1hbGlkcF9wbGFuZSAqcGxhbmUsCiAJfQogfQogCitzdGF0aWMgdm9pZCBtYWxp ZHBfc2V0X3BsYW5lX2Jhc2VfYWRkcihzdHJ1Y3QgZHJtX2ZyYW1lYnVmZmVyICpmYiwKKwkJCQkg ICAgICAgc3RydWN0IG1hbGlkcF9wbGFuZSAqbXAsCisJCQkJICAgICAgIGludCBwbGFuZV9pbmRl eCkKK3sKKwlkbWFfYWRkcl90IHBhZGRyOworCXUxNiBwdHI7CisJc3RydWN0IGRybV9wbGFuZSAq cGxhbmUgPSAmbXAtPmJhc2U7CisJYm9vbCBhZmJjID0gZmItPm1vZGlmaWVyID8gdHJ1ZSA6IGZh bHNlOworCisJcHRyID0gbXAtPmxheWVyLT5wdHIgKyAocGxhbmVfaW5kZXggPDwgNCk7CisKKwkv KgorCSAqIEZvciBBRkJDIGJ1ZmZlcnMsIGNyb3BwaW5nIGlzIGhhbmRsZWQgYnkgQUZCQyBkZWNv ZGVyIHJhdGhlciB0aGFuCisJICogcG9pbnRlciBtYW5pcHVsYXRpb24uCisJICovCisJaWYgKCFh ZmJjKSB7CisJCXBhZGRyID0gZHJtX2ZiX2NtYV9nZXRfZ2VtX2FkZHIoZmIsIHBsYW5lLT5zdGF0 ZSwKKwkJCQkJCXBsYW5lX2luZGV4KTsKKwl9IGVsc2UgeworCQlzdHJ1Y3QgZHJtX2dlbV9jbWFf b2JqZWN0ICpvYmo7CisKKwkJb2JqID0gZHJtX2ZiX2NtYV9nZXRfZ2VtX29iaihmYiwgcGxhbmVf aW5kZXgpOworCisJCWlmIChXQVJOX09OKCFvYmopKQorCQkJcmV0dXJuOworCQlwYWRkciA9IG9i ai0+cGFkZHI7CisJfQorCisJbWFsaWRwX2h3X3dyaXRlKG1wLT5od2RldiwgbG93ZXJfMzJfYml0 cyhwYWRkciksIHB0cik7CisJbWFsaWRwX2h3X3dyaXRlKG1wLT5od2RldiwgdXBwZXJfMzJfYml0 cyhwYWRkciksIHB0ciArIDQpOworfQorCitzdGF0aWMgdm9pZCBtYWxpZHBfZGVfc2V0X3BsYW5l X2FmYmMoc3RydWN0IGRybV9wbGFuZSAqcGxhbmUpCit7CisJc3RydWN0IG1hbGlkcF9wbGFuZSAq bXA7CisJdTMyIHNyY193LCBzcmNfaCwgdmFsID0gMCwgc3JjX3gsIHNyY195OworCXN0cnVjdCBk cm1fZnJhbWVidWZmZXIgKmZiID0gcGxhbmUtPnN0YXRlLT5mYjsKKworCW1wID0gdG9fbWFsaWRw X3BsYW5lKHBsYW5lKTsKKworCWlmICghZmItPm1vZGlmaWVyKSB7CisJCW1hbGlkcF9od193cml0 ZShtcC0+aHdkZXYsIDAsIG1wLT5sYXllci0+YWZiY19kZWNvZGVyX29mZnNldCk7CisJCXJldHVy bjsKKwl9CisKKwkvKiBjb252ZXJ0IHNyYyB2YWx1ZXMgZnJvbSBRMTYgZml4ZWQgcG9pbnQgdG8g aW50ZWdlciAqLworCXNyY193ID0gcGxhbmUtPnN0YXRlLT5zcmNfdyA+PiAxNjsKKwlzcmNfaCA9 IHBsYW5lLT5zdGF0ZS0+c3JjX2ggPj4gMTY7CisJc3JjX3ggPSBwbGFuZS0+c3RhdGUtPnNyY194 ID4+IDE2OworCXNyY195ID0gcGxhbmUtPnN0YXRlLT5zcmNfeSA+PiAxNjsKKworCXZhbCA9ICgo ZmItPndpZHRoIC0gKHNyY194ICsgc3JjX3cpKSA8PCBNQUxJRFBfQURfQ1JPUF9SSUdIVF9PRkZT RVQpIHwKKwkJICAgc3JjX3g7CisJbWFsaWRwX2h3X3dyaXRlKG1wLT5od2RldiwgdmFsLAorCQkJ bXAtPmxheWVyLT5hZmJjX2RlY29kZXJfb2Zmc2V0ICsgTUFMSURQX0FEX0NST1BfSCk7CisKKwl2 YWwgPSAoKGZiLT5oZWlnaHQgLSAoc3JjX3kgKyBzcmNfaCkpIDw8IE1BTElEUF9BRF9DUk9QX0JP VFRPTV9PRkZTRVQpIHwKKwkJICAgc3JjX3k7CisJbWFsaWRwX2h3X3dyaXRlKG1wLT5od2Rldiwg dmFsLAorCQkJbXAtPmxheWVyLT5hZmJjX2RlY29kZXJfb2Zmc2V0ICsgTUFMSURQX0FEX0NST1Bf Vik7CisKKwl2YWwgPSBNQUxJRFBfQURfRU47CisJaWYgKGZiLT5tb2RpZmllciAmIEFGQkNfRk9S TUFUX01PRF9TUExJVCkKKwkJdmFsIHw9IE1BTElEUF9BRF9CUzsKKwlpZiAoZmItPm1vZGlmaWVy ICYgQUZCQ19GT1JNQVRfTU9EX1lUUikKKwkJdmFsIHw9IE1BTElEUF9BRF9ZVFI7CisKKwltYWxp ZHBfaHdfd3JpdGUobXAtPmh3ZGV2LCB2YWwsIG1wLT5sYXllci0+YWZiY19kZWNvZGVyX29mZnNl dCk7Cit9CisKIHN0YXRpYyB2b2lkIG1hbGlkcF9kZV9wbGFuZV91cGRhdGUoc3RydWN0IGRybV9w bGFuZSAqcGxhbmUsCiAJCQkJICAgc3RydWN0IGRybV9wbGFuZV9zdGF0ZSAqb2xkX3N0YXRlKQog ewpAQCAtMzM4LDYgKzQwOCw3IEBAIHN0YXRpYyB2b2lkIG1hbGlkcF9kZV9wbGFuZV91cGRhdGUo c3RydWN0IGRybV9wbGFuZSAqcGxhbmUsCiAJdTMyIHNyY193LCBzcmNfaCwgZGVzdF93LCBkZXN0 X2gsIHZhbDsKIAlpbnQgaTsKIAlib29sIGZvcm1hdF9oYXNfYWxwaGEgPSBwbGFuZS0+c3RhdGUt PmZiLT5mb3JtYXQtPmhhc19hbHBoYTsKKwlzdHJ1Y3QgZHJtX2ZyYW1lYnVmZmVyICpmYiA9IHBs YW5lLT5zdGF0ZS0+ZmI7CiAKIAltcCA9IHRvX21hbGlkcF9wbGFuZShwbGFuZSk7CiAKQEAgLTM0 OSwxNSArNDIwLDkgQEAgc3RhdGljIHZvaWQgbWFsaWRwX2RlX3BsYW5lX3VwZGF0ZShzdHJ1Y3Qg ZHJtX3BsYW5lICpwbGFuZSwKIAogCW1hbGlkcF9od193cml0ZShtcC0+aHdkZXYsIG1zLT5mb3Jt YXQsIG1wLT5sYXllci0+YmFzZSk7CiAKLQlmb3IgKGkgPSAwOyBpIDwgbXMtPm5fcGxhbmVzOyBp KyspIHsKLQkJLyogY2FsY3VsYXRlIHRoZSBvZmZzZXQgZm9yIHRoZSBsYXllcidzIHBsYW5lIHJl Z2lzdGVycyAqLwotCQl1MTYgcHRyID0gbXAtPmxheWVyLT5wdHIgKyAoaSA8PCA0KTsKLQkJZG1h X2FkZHJfdCBmYl9hZGRyID0gZHJtX2ZiX2NtYV9nZXRfZ2VtX2FkZHIocGxhbmUtPnN0YXRlLT5m YiwKLQkJCQkJCQkgICAgIHBsYW5lLT5zdGF0ZSwgaSk7CisJZm9yIChpID0gMDsgaSA8IG1zLT5u X3BsYW5lczsgaSsrKQorCQltYWxpZHBfc2V0X3BsYW5lX2Jhc2VfYWRkcihmYiwgbXAsIGkpOwog Ci0JCW1hbGlkcF9od193cml0ZShtcC0+aHdkZXYsIGxvd2VyXzMyX2JpdHMoZmJfYWRkciksIHB0 cik7Ci0JCW1hbGlkcF9od193cml0ZShtcC0+aHdkZXYsIHVwcGVyXzMyX2JpdHMoZmJfYWRkciks IHB0ciArIDQpOwotCX0KIAltYWxpZHBfZGVfc2V0X3BsYW5lX3BpdGNoZXMobXAsIG1zLT5uX3Bs YW5lcywKIAkJCQkgICAgcGxhbmUtPnN0YXRlLT5mYi0+cGl0Y2hlcyk7CiAKQEAgLTM4MSw2ICs0 NDYsOCBAQCBzdGF0aWMgdm9pZCBtYWxpZHBfZGVfcGxhbmVfdXBkYXRlKHN0cnVjdCBkcm1fcGxh bmUgKnBsYW5lLAogCQkJCUxBWUVSX0hfVkFMKHNyY193KSB8IExBWUVSX1ZfVkFMKHNyY19oKSwK IAkJCQltcC0+bGF5ZXItPmJhc2UgKyBNQUxJRFA1NTBfTFNfUjFfSU5fU0laRSk7CiAKKwltYWxp ZHBfZGVfc2V0X3BsYW5lX2FmYmMocGxhbmUpOworCiAJLyogZmlyc3QgY2xlYXIgdGhlIHJvdGF0 aW9uIGJpdHMgKi8KIAl2YWwgPSBtYWxpZHBfaHdfcmVhZChtcC0+aHdkZXYsIG1wLT5sYXllci0+ YmFzZSArIE1BTElEUF9MQVlFUl9DT05UUk9MKTsKIAl2YWwgJj0gfkxBWUVSX1JPVF9NQVNLOwpk aWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2FybS9tYWxpZHBfcmVncy5oIGIvZHJpdmVycy9n cHUvZHJtL2FybS9tYWxpZHBfcmVncy5oCmluZGV4IDE0OTAyNGYuLjU0ZjRlYzUgMTAwNjQ0Ci0t LSBhL2RyaXZlcnMvZ3B1L2RybS9hcm0vbWFsaWRwX3JlZ3MuaAorKysgYi9kcml2ZXJzL2dwdS9k cm0vYXJtL21hbGlkcF9yZWdzLmgKQEAgLTE4MCwxMCArMTgwLDEzIEBACiAjZGVmaW5lIE1BTElE UDUwMF9MVl9ZVVYyUkdCCQkoKHMxNikoLTB4QjgpKQogI2RlZmluZSBNQUxJRFA1MDBfREVfTFZf QkFTRQkJMHgwMDEwMAogI2RlZmluZSBNQUxJRFA1MDBfREVfTFZfUFRSX0JBU0UJMHgwMDEyNAor I2RlZmluZSBNQUxJRFA1MDBfREVfTFZfQURfQ1RSTAkJMHgwMDQwMAogI2RlZmluZSBNQUxJRFA1 MDBfREVfTEcxX0JBU0UJCTB4MDAyMDAKICNkZWZpbmUgTUFMSURQNTAwX0RFX0xHMV9QVFJfQkFT RQkweDAwMjFjCisjZGVmaW5lIE1BTElEUDUwMF9ERV9MRzFfQURfQ1RSTAkweDAwNDBjCiAjZGVm aW5lIE1BTElEUDUwMF9ERV9MRzJfQkFTRQkJMHgwMDMwMAogI2RlZmluZSBNQUxJRFA1MDBfREVf TEcyX1BUUl9CQVNFCTB4MDAzMWMKKyNkZWZpbmUgTUFMSURQNTAwX0RFX0xHMl9BRF9DVFJMCTB4 MDA0MTgKICNkZWZpbmUgTUFMSURQNTAwX1NFX0JBU0UJCTB4MDBjMDAKICNkZWZpbmUgTUFMSURQ NTAwX1NFX0NPTlRST0wJCTB4MDBjMGMKICNkZWZpbmUgTUFMSURQNTAwX1NFX1BUUl9CQVNFCQkw eDAwZTBjCkBAIC0yMDgsMTAgKzIxMSwxMyBAQAogI2RlZmluZSBNQUxJRFA1NTBfTFZfWVVWMlJH QgkJMHgwMDA4NAogI2RlZmluZSBNQUxJRFA1NTBfREVfTFYxX0JBU0UJCTB4MDAxMDAKICNkZWZp bmUgTUFMSURQNTUwX0RFX0xWMV9QVFJfQkFTRQkweDAwMTI0CisjZGVmaW5lIE1BTElEUDU1MF9E RV9MVjFfQURfQ1RSTAkweDAwMUI4CiAjZGVmaW5lIE1BTElEUDU1MF9ERV9MVjJfQkFTRQkJMHgw MDIwMAogI2RlZmluZSBNQUxJRFA1NTBfREVfTFYyX1BUUl9CQVNFCTB4MDAyMjQKKyNkZWZpbmUg TUFMSURQNTUwX0RFX0xWMl9BRF9DVFJMCTB4MDAyQjgKICNkZWZpbmUgTUFMSURQNTUwX0RFX0xH X0JBU0UJCTB4MDAzMDAKICNkZWZpbmUgTUFMSURQNTUwX0RFX0xHX1BUUl9CQVNFCTB4MDAzMWMK KyNkZWZpbmUgTUFMSURQNTUwX0RFX0xHX0FEX0NUUkwJCTB4MDAzMzAKICNkZWZpbmUgTUFMSURQ NTUwX0RFX0xTX0JBU0UJCTB4MDA0MDAKICNkZWZpbmUgTUFMSURQNTUwX0RFX0xTX1BUUl9CQVNF CTB4MDA0MmMKICNkZWZpbmUgTUFMSURQNTUwX0RFX1BFUkZfQkFTRQkJMHgwMDUwMApAQCAtMjIz LDYgKzIyOSwyMCBAQAogI2RlZmluZSBNQUxJRFA1NTBfQ09ORklHX1ZBTElECQkweDBjMDE0CiAj ZGVmaW5lIE1BTElEUDU1MF9DT05GSUdfSUQJCTB4MGZmZDQKIAorLyogQUZCQyByZWdpc3RlciBv ZmZzZXRzIHJlbGF0aXZlIHRvIE1BTElEUFhYWF9ERV9MWF9BRF9DVFJMICovCisvKiBUaGUgZm9s bG93aW5nIHJlZ2lzdGVyIG9mZnNldHMgYXJlIGNvbW1vbiBmb3IgRFA1MDAsIERQNTUwIGFuZCBE UDY1MCAqLworI2RlZmluZSBNQUxJRFBfQURfQ1JPUF9IICAgICAgICAgICAgICAgIDB4NAorI2Rl ZmluZSBNQUxJRFBfQURfQ1JPUF9WICAgICAgICAgICAgICAgIDB4OAorI2RlZmluZSBNQUxJRFBf QURfRU5EX1BUUl9MT1cgICAgICAgICAgIDB4YworI2RlZmluZSBNQUxJRFBfQURfRU5EX1BUUl9I SUdIICAgICAgICAgIDB4MTAKKworLyogQUZCQyBkZWNvZGVyIFJlZ2lzdGVycyAqLworI2RlZmlu ZSBNQUxJRFBfQURfRU4gICAgICAgICAgICAgICAgICAgIEJJVCgwKQorI2RlZmluZSBNQUxJRFBf QURfWVRSICAgICAgICAgICAgICAgICAgIEJJVCg0KQorI2RlZmluZSBNQUxJRFBfQURfQlMgICAg ICAgICAgICAgICAgICAgIEJJVCg4KQorI2RlZmluZSBNQUxJRFBfQURfQ1JPUF9SSUdIVF9PRkZT RVQgICAgIDE2CisjZGVmaW5lIE1BTElEUF9BRF9DUk9QX0JPVFRPTV9PRkZTRVQgICAgMTYKKwog LyoKICAqIFN0YXJ0aW5nIHdpdGggRFA1NTAgdGhlIHJlZ2lzdGVyIG1hcCBibG9ja3MgaGFzIGJl ZW4gc3RhbmRhcmRpc2VkIHRvIHRoZQogICogZm9sbG93aW5nIGxheW91dDoKLS0gCjIuNy40Cgpf X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpkcmktZGV2ZWwg bWFpbGluZyBsaXN0CmRyaS1kZXZlbEBsaXN0cy5mcmVlZGVza3RvcC5vcmcKaHR0cHM6Ly9saXN0 cy5mcmVlZGVza3RvcC5vcmcvbWFpbG1hbi9saXN0aW5mby9kcmktZGV2ZWwK