From mboxrd@z Thu Jan 1 00:00:00 1970 From: Radhakrishna Sripada Subject: [PATCH v6 10/10] drm/i915/tgl: Add Clear Color supoort for TGL Render Decompression Date: Mon, 28 Oct 2019 11:58:35 -0700 Message-ID: <20191028185835.13004-1-radhakrishna.sripada@intel.com> References: <20191023000922.32247-1-radhakrishna.sripada@intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by gabe.freedesktop.org (Postfix) with ESMTPS id 10EF76E9D2 for ; Mon, 28 Oct 2019 18:56:41 +0000 (UTC) In-Reply-To: <20191023000922.32247-1-radhakrishna.sripada@intel.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" To: intel-gfx@lists.freedesktop.org Cc: Nanley G Chery , Dhinakaran Pandiyan , Ville Syrjala List-Id: intel-gfx@lists.freedesktop.org UmVuZGVyIERlY29tcHJlc3Npb24gaXMgc3VwcG9ydGVkIHdpdGggWS1UaWxlZCBtYWluIHN1cmZh Y2UuIFRoZSBDQ1MgaXMKbGluZWFyIGFuZCBoYXMgNCBiaXRzIG9mIGRhdGEgZm9yIGVhY2ggbWFp biBzdXJmYWNlIGNhY2hlIGxpbmUgcGFpciwgYQpyYXRpbyBvZiAxOjI1Ni4gQWRkaXRpb25hbCBD bGVhciBDb2xvciBpbmZvcm1hdGlvbiBpcyBwYXNzZWQgZnJvbSB0aGUKdXNlci1zcGFjZSB0aHJv dWdoIGFuIG9mZnNldCBpbiB0aGUgR0VNIEJPLiBBZGQgYSBuZXcgbW9kaWZpZXIgdG8gaWRlbnRp ZnkKYW5kIHBhcnNlIG5ldyBDbGVhciBDb2xvciBpbmZvcm1hdGlvbiBhbmQgZXh0ZW5kIEdlbjEy IHJlbmRlciBkZWNvbXByZXNzaW9uCmZ1bmN0aW9uYWxpdHkgdG8gdGhlIG5ld2x5IGFkZGVkIG1v ZGlmaWVyLgoKdjI6IEZpeCBoYXNfYWxwaGEgZmxhZyBmb3IgbW9kaWZpZXJzLCBvbWl0IENDIG1v ZGlmaWVyIGR1cmluZyBpbml0aWFsCiAgICBwbGFuZSBjb25maWcoTWF0dCkuIEZpeCBMb29rdXAg ZXJyb3IuCnYzOiBGaXggdGhlIHBhbmljIHdoaWxlIHJ1bm5pbmcga21zX2N1YmUKdjQ6IEFkZCBh bGlnbm1lbnQgY2hlY2sgYW5kIHJldXNlIHRoZSBjb21tZW50cyBmb3IgZ2UxMl9jY3NfZm9ybWF0 cyhNYXR0KQp2NTogRml4IHR5cG9zIGFuZCB3cmFwIGNvbW1lbnRzKE1hdHQpCgpDYzogRGhpbmFr YXJhbiBQYW5kaXlhbiA8ZGhpbmFrYXJhbi5wYW5kaXlhbkBpbnRlbC5jb20+CkNjOiBWaWxsZSBT eXJqYWxhIDx2aWxsZS5zeXJqYWxhQGludGVsLmNvbT4KQ2M6IFNoYXNoYW5rIFNoYXJtYSA8c2hh c2hhbmsuc2hhcm1hQGludGVsLmNvbT4KQ2M6IFJhZmFlbCBBbnRvZ25vbGxpIDxyYWZhZWwuYW50 b2dub2xsaUBpbnRlbC5jb20+CkNjOiBOYW5sZXkgRyBDaGVyeSA8bmFubGV5LmcuY2hlcnlAaW50 ZWwuY29tPgpSZXZpZXdlZC1ieTogTWF0dCBSb3BlciA8bWF0dGhldy5kLnJvcGVyQGludGVsLmNv bT4KU2lnbmVkLW9mZi1ieTogUmFkaGFrcmlzaG5hIFNyaXBhZGEgPHJhZGhha3Jpc2huYS5zcmlw YWRhQGludGVsLmNvbT4KLS0tCiBkcml2ZXJzL2dwdS9kcm0vaTkxNS9kaXNwbGF5L2ludGVsX2Rp c3BsYXkuYyAgfCA1MiArKysrKysrKysrKysrKysrKysrCiAuLi4vZHJtL2k5MTUvZGlzcGxheS9p bnRlbF9kaXNwbGF5X3R5cGVzLmggICAgfCAgMyArKwogZHJpdmVycy9ncHUvZHJtL2k5MTUvZGlz cGxheS9pbnRlbF9zcHJpdGUuYyAgIHwgMTEgKysrLQogZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkx NV9yZWcuaCAgICAgICAgICAgICAgIHwgMTIgKysrKysKIDQgZmlsZXMgY2hhbmdlZCwgNzcgaW5z ZXJ0aW9ucygrKSwgMSBkZWxldGlvbigtKQoKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9p OTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheS5jIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvZGlzcGxh eS9pbnRlbF9kaXNwbGF5LmMKaW5kZXggMjBhZDA4OWRhNmVlLi42ZDZlYWI4ZDQ3NzYgMTAwNjQ0 Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheS5jCisrKyBi L2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheS5jCkBAIC0xOTQ0LDYg KzE5NDQsMTAgQEAgaW50ZWxfdGlsZV93aWR0aF9ieXRlcyhjb25zdCBzdHJ1Y3QgZHJtX2ZyYW1l YnVmZmVyICpmYiwgaW50IGNvbG9yX3BsYW5lKQogCQlpZiAoY29sb3JfcGxhbmUgPT0gMSkKIAkJ CXJldHVybiA2NDsKIAkJLyogZmFsbCB0aHJvdWdoICovCisJY2FzZSBJOTE1X0ZPUk1BVF9NT0Rf WV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0M6CisJCWlmIChjb2xvcl9wbGFuZSA9PSAxIHx8IGNvbG9y X3BsYW5lID09IDIpCisJCQlyZXR1cm4gNjQ7CisJCS8qIGZhbGwgdGhyb3VnaCAqLwogCWNhc2Ug STkxNV9GT1JNQVRfTU9EX1lfVElMRUQ6CiAJCWlmIChJU19HRU4oZGV2X3ByaXYsIDIpIHx8IEhB U18xMjhfQllURV9ZX1RJTElORyhkZXZfcHJpdikpCiAJCQlyZXR1cm4gMTI4OwpAQCAtMjA4NSw2 ICsyMDg5LDcgQEAgc3RhdGljIHVuc2lnbmVkIGludCBpbnRlbF9zdXJmX2FsaWdubWVudChjb25z dCBzdHJ1Y3QgZHJtX2ZyYW1lYnVmZmVyICpmYiwKIAkJCXJldHVybiAyNTYgKiAxMDI0OwogCQly ZXR1cm4gMDsKIAljYXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDUzoKKwlj YXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDU19DQzoKIAkJcmV0dXJuIDE2 ICogMTAyNDsKIAljYXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0NDUzoKIAljYXNlIEk5MTVf Rk9STUFUX01PRF9ZZl9USUxFRF9DQ1M6CkBAIC0yMjg3LDYgKzIyOTIsOCBAQCBzdGF0aWMgYm9v bCBpc19zdXJmYWNlX2xpbmVhcih1NjQgbW9kaWZpZXIsIGludCBjb2xvcl9wbGFuZSkKIAkJcmV0 dXJuIHRydWU7CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1M6CiAJ CXJldHVybiBjb2xvcl9wbGFuZSA9PSAxOworCWNhc2UgSTkxNV9GT1JNQVRfTU9EX1lfVElMRURf R0VOMTJfUkNfQ0NTX0NDOgorCQlyZXR1cm4gY29sb3JfcGxhbmUgPT0gMSB8fCBjb2xvcl9wbGFu ZSA9PSAyOwogCWNhc2UgSTkxNV9GT1JNQVRfTU9EX1lfVElMRURfR0VOMTJfTUNfQ0NTOgogCQly ZXR1cm4gY29sb3JfcGxhbmUgPT0gMSB8fCBjb2xvcl9wbGFuZSA9PSAzOwogCWRlZmF1bHQ6CkBA IC0yNDgwLDYgKzI0ODcsNyBAQCBzdGF0aWMgdW5zaWduZWQgaW50IGludGVsX2ZiX21vZGlmaWVy X3RvX3RpbGluZyh1NjQgZmJfbW9kaWZpZXIpCiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxF RF9DQ1M6CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1M6CiAJY2Fz ZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9NQ19DQ1M6CisJY2FzZSBJOTE1X0ZPUk1B VF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0M6CiAJCXJldHVybiBJOTE1X1RJTElOR19ZOwog CWRlZmF1bHQ6CiAJCXJldHVybiBJOTE1X1RJTElOR19OT05FOwpAQCAtMjUzMyw2ICsyNTQxLDIx IEBAIHN0YXRpYyBjb25zdCBzdHJ1Y3QgZHJtX2Zvcm1hdF9pbmZvIGdlbjEyX2Njc19mb3JtYXRz W10gPSB7CiAJICAuY3BwID0geyAxLCAxLCAyLCAxfSwgLmhzdWIgPSAyLCAudnN1YiA9IDIsIC5p c195dXYgPSB0cnVlIH0sCiB9OwogCisvKgorICogU2FtZSBhcyBnZW4xMl9jY3NfZm9ybWF0c1td IGFib3ZlLCBidXQgd2l0aCBhZGRpdGlvbmFsIHN1cmZhY2UgdXNlZAorICogdG8gcGFzcyBDbGVh ciBDb2xvciBpbmZvcm1hdGlvbiBpbiBwbGFuZSAyIHdpdGggNjQgYml0cyBvZiBkYXRhLgorICov CitzdGF0aWMgY29uc3Qgc3RydWN0IGRybV9mb3JtYXRfaW5mbyBnZW4xMl9jY3NfY2NfZm9ybWF0 c1tdID0geworCXsgLmZvcm1hdCA9IERSTV9GT1JNQVRfWFJHQjg4ODgsIC5kZXB0aCA9IDI0LCAu bnVtX3BsYW5lcyA9IDMsCisJICAuY3BwID0geyA0LCAxLCAwLCB9LCAuaHN1YiA9IDIsIC52c3Vi ID0gMzIsIH0sCisJeyAuZm9ybWF0ID0gRFJNX0ZPUk1BVF9YQkdSODg4OCwgLmRlcHRoID0gMjQs IC5udW1fcGxhbmVzID0gMywKKwkgIC5jcHAgPSB7IDQsIDEsIDAsIH0sIC5oc3ViID0gMiwgLnZz dWIgPSAzMiwgfSwKKwl7IC5mb3JtYXQgPSBEUk1fRk9STUFUX0FSR0I4ODg4LCAuZGVwdGggPSAz MiwgLm51bV9wbGFuZXMgPSAzLAorCSAgLmNwcCA9IHsgNCwgMSwgMCwgfSwgLmhzdWIgPSAyLCAu dnN1YiA9IDMyLCAuaGFzX2FscGhhID0gdHJ1ZSB9LAorCXsgLmZvcm1hdCA9IERSTV9GT1JNQVRf QUJHUjg4ODgsIC5kZXB0aCA9IDMyLCAubnVtX3BsYW5lcyA9IDMsCisJICAuY3BwID0geyA0LCAx LCAwLCB9LCAuaHN1YiA9IDIsIC52c3ViID0gMzIsIC5oYXNfYWxwaGEgPSB0cnVlIH0sCit9Owor CiBzdGF0aWMgY29uc3Qgc3RydWN0IGRybV9mb3JtYXRfaW5mbyAqCiBsb29rdXBfZm9ybWF0X2lu Zm8oY29uc3Qgc3RydWN0IGRybV9mb3JtYXRfaW5mbyBmb3JtYXRzW10sCiAJCSAgIGludCBudW1f Zm9ybWF0cywgdTMyIGZvcm1hdCkKQEAgLTI1NjAsNiArMjU4MywxMCBAQCBpbnRlbF9nZXRfZm9y bWF0X2luZm8oY29uc3Qgc3RydWN0IGRybV9tb2RlX2ZiX2NtZDIgKmNtZCkKIAkJcmV0dXJuIGxv b2t1cF9mb3JtYXRfaW5mbyhnZW4xMl9jY3NfZm9ybWF0cywKIAkJCQkJICBBUlJBWV9TSVpFKGdl bjEyX2Njc19mb3JtYXRzKSwKIAkJCQkJICBjbWQtPnBpeGVsX2Zvcm1hdCk7CisJY2FzZSBJOTE1 X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0M6CisJCXJldHVybiBsb29rdXBfZm9y bWF0X2luZm8oZ2VuMTJfY2NzX2NjX2Zvcm1hdHMsCisJCQkJCSAgQVJSQVlfU0laRShnZW4xMl9j Y3NfY2NfZm9ybWF0cyksCisJCQkJCSAgY21kLT5waXhlbF9mb3JtYXQpOwogCWRlZmF1bHQ6CiAJ CXJldHVybiBOVUxMOwogCX0KQEAgLTI1NjksNiArMjU5Niw3IEBAIGJvb2wgaXNfY2NzX21vZGlm aWVyKHU2NCBtb2RpZmllcikKIHsKIAlyZXR1cm4gbW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9E X1lfVElMRURfR0VOMTJfUkNfQ0NTIHx8CiAJICAgICAgIG1vZGlmaWVyID09IEk5MTVfRk9STUFU X01PRF9ZX1RJTEVEX0dFTjEyX01DX0NDUyB8fAorCSAgICAgICBtb2RpZmllciA9PSBJOTE1X0ZP Uk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0MgfHwKIAkgICAgICAgbW9kaWZpZXIgPT0g STkxNV9GT1JNQVRfTU9EX1lfVElMRURfQ0NTIHx8CiAJICAgICAgIG1vZGlmaWVyID09IEk5MTVf Rk9STUFUX01PRF9ZZl9USUxFRF9DQ1M7CiB9CkBAIC0yNzU2LDYgKzI3ODQsOCBAQCBzdGF0aWMg Ym9vbCBpc19jY3NfcGxhbmUodTY0IG1vZGlmaWVyLCBpbnQgY29sb3JfcGxhbmUpCiAJCXJldHVy biBmYWxzZTsKIAllbHNlIGlmIChtb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9H RU4xMl9NQ19DQ1MpCiAJCXJldHVybiBjb2xvcl9wbGFuZSA9PSAzIHx8IGNvbG9yX3BsYW5lID09 IDE7CisJZWxzZSBpZiAobW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9EX1lfVElMRURfR0VOMTJf UkNfQ0NTX0NDKQorCQlyZXR1cm4gY29sb3JfcGxhbmUgPT0gMSB8fCBjb2xvcl9wbGFuZSA9PSAy OwogCWVsc2UKIAkJcmV0dXJuIGNvbG9yX3BsYW5lID09IDE7CiB9CkBAIC0yODI0LDYgKzI4NTQs MTggQEAgaW50ZWxfZmlsbF9mYl9pbmZvKHN0cnVjdCBkcm1faTkxNV9wcml2YXRlICpkZXZfcHJp diwKIAkJaW50IHgsIHk7CiAJCWludCByZXQ7CiAKKwkJLyoKKwkJICogUGxhbmUgMiBvZiBSZW5k ZXIgQ29tcHJlc3Npb24gd2l0aCBDbGVhciBDb2xvciBmYiBtb2RpZmllcgorCQkgKiBpcyBjb25z dW1lZCBieSB0aGUgZHJpdmVyIGFuZCBub3QgcGFzc2VkIHRvIERFLiBTa2lwIHRoZQorCQkgKiBh cml0aG1ldGljIHJlbGF0ZWQgdG8gYWxpZ25tZW50IGFuZCBvZmZzZXQgY2FsY3VsYXRpb24uCisJ CSAqLworCQlpZiAoaSA9PSAyICYmIGZiLT5tb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9U SUxFRF9HRU4xMl9SQ19DQ1NfQ0MpIHsKKwkJCWlmIChJU19BTElHTkVEKGZiLT5vZmZzZXRzWzJd LCBQQUdFX1NJWkUpKQorCQkJCWNvbnRpbnVlOworCQkJZWxzZQorCQkJCXJldHVybiAtRUlOVkFM OworCQl9CisKIAkJY3BwID0gZmItPmZvcm1hdC0+Y3BwW2ldOwogCQlpbnRlbF9mYl9wbGFuZV9k aW1zKCZ3aWR0aCwgJmhlaWdodCwgZmIsIGkpOwogCkBAIC00MzQxLDYgKzQzODMsNyBAQCBzdGF0 aWMgdTMyIHNrbF9wbGFuZV9jdGxfdGlsaW5nKHU2NCBmYl9tb2RpZmllcikKIAljYXNlIEk5MTVf Rk9STUFUX01PRF9ZX1RJTEVEOgogCQlyZXR1cm4gUExBTkVfQ1RMX1RJTEVEX1k7CiAJY2FzZSBJ OTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9DQ1M6CisJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxF RF9HRU4xMl9SQ19DQ1NfQ0M6CiAJCXJldHVybiBQTEFORV9DVExfVElMRURfWSB8IFBMQU5FX0NU TF9SRU5ERVJfREVDT01QUkVTU0lPTl9FTkFCTEU7CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9U SUxFRF9HRU4xMl9SQ19DQ1M6CiAJCXJldHVybiBQTEFORV9DVExfVElMRURfWSB8CkBAIC0xNTIx Miw2ICsxNTI1NSwxNSBAQCBzdGF0aWMgaW50IGludGVsX3BsYW5lX3Bpbl9mYihzdHJ1Y3QgaW50 ZWxfcGxhbmVfc3RhdGUgKnBsYW5lX3N0YXRlKQogCiAJcGxhbmVfc3RhdGUtPnZtYSA9IHZtYTsK IAorCWlmIChmYi0+bW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9EX1lfVElMRURfR0VOMTJfUkNf Q0NTX0NDKSB7CisJCXUzMiAqY2NhZGRyID0ga21hcF9hdG9taWMoaTkxNV9nZW1fb2JqZWN0X2dl dF9wYWdlKGludGVsX2ZiX29iaihmYiksCisJCQkJCQkJCSAgZmItPm9mZnNldHNbMl0gPj4gUEFH RV9TSElGVCkpOworCisJCXBsYW5lX3N0YXRlLT5jY3ZhbCA9ICgodTY0KSooY2NhZGRyICsgQ0Nf VkFMX0hJR0hFUl9PRkZTRVQpIDw8IDMyKQorCQkJCSAgICAgfCAqKGNjYWRkciArIENDX1ZBTF9M T1dFUl9PRkZTRVQpOworCQlrdW5tYXBfYXRvbWljKGNjYWRkcik7CisJfQorCiAJcmV0dXJuIDA7 CiB9CiAKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlz cGxheV90eXBlcy5oIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvZGlzcGxheS9pbnRlbF9kaXNwbGF5 X3R5cGVzLmgKaW5kZXggZTk4ZjIxMjY4MmY2Li45ZTE0N2JiYTA5MmUgMTAwNjQ0Ci0tLSBhL2Ry aXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheV90eXBlcy5oCisrKyBiL2Ry aXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheV90eXBlcy5oCkBAIC01ODcs NiArNTg3LDkgQEAgc3RydWN0IGludGVsX3BsYW5lX3N0YXRlIHsKIAl1MzIgcGxhbmFyX3NsYXZl OwogCiAJc3RydWN0IGRybV9pbnRlbF9zcHJpdGVfY29sb3JrZXkgY2tleTsKKworCS8qIENsZWFy IENvbG9yIFZhbHVlICovCisJdTY0IGNjdmFsOwogfTsKIAogc3RydWN0IGludGVsX2luaXRpYWxf cGxhbmVfY29uZmlnIHsKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkv aW50ZWxfc3ByaXRlLmMgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9kaXNwbGF5L2ludGVsX3Nwcml0 ZS5jCmluZGV4IGE1MDE4ZmZmYThmMi4uZjhkMjk4NWU2YzAxIDEwMDY0NAotLS0gYS9kcml2ZXJz L2dwdS9kcm0vaTkxNS9kaXNwbGF5L2ludGVsX3Nwcml0ZS5jCisrKyBiL2RyaXZlcnMvZ3B1L2Ry bS9pOTE1L2Rpc3BsYXkvaW50ZWxfc3ByaXRlLmMKQEAgLTU5Niw2ICs1OTYsNyBAQCBza2xfcHJv Z3JhbV9wbGFuZShzdHJ1Y3QgaW50ZWxfcGxhbmUgKnBsYW5lLAogCXUzMiBwbGFuZV9jb2xvcl9j dGwgPSAwOwogCXVuc2lnbmVkIGxvbmcgaXJxZmxhZ3M7CiAJdTMyIGtleW1zaywga2V5bWF4Owor CXU2NCBjY3ZhbCA9IHBsYW5lX3N0YXRlLT5jY3ZhbDsKIAogCXBsYW5lX2N0bCB8PSBza2xfcGxh bmVfY3RsX2NydGMoY3J0Y19zdGF0ZSk7CiAKQEAgLTY1Niw2ICs2NTcsMTAgQEAgc2tsX3Byb2dy YW1fcGxhbmUoc3RydWN0IGludGVsX3BsYW5lICpwbGFuZSwKIAlpZiAoZmItPmZvcm1hdC0+aXNf eXV2ICYmIGljbF9pc19oZHJfcGxhbmUoZGV2X3ByaXYsIHBsYW5lX2lkKSkKIAkJaWNsX3Byb2dy YW1faW5wdXRfY3NjKHBsYW5lLCBjcnRjX3N0YXRlLCBwbGFuZV9zdGF0ZSk7CiAKKwlpZiAoZmIt Pm1vZGlmaWVyID09IEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDU19DQykKKwkJ aW50ZWxfdW5jb3JlX3dyaXRlNjRfZncoJmRldl9wcml2LT51bmNvcmUsCisJCQkJCVBMQU5FX0ND X1ZBTChwaXBlLCBwbGFuZV9pZCksIGNjdmFsKTsKKwogCXNrbF93cml0ZV9wbGFuZV93bShwbGFu ZSwgY3J0Y19zdGF0ZSk7CiAKIAlJOTE1X1dSSVRFX0ZXKFBMQU5FX0tFWVZBTChwaXBlLCBwbGFu ZV9pZCksIGtleS0+bWluX3ZhbHVlKTsKQEAgLTIxMTUsNyArMjEyMCw4IEBAIHN0YXRpYyBpbnQg c2tsX3BsYW5lX2NoZWNrX2ZiKGNvbnN0IHN0cnVjdCBpbnRlbF9jcnRjX3N0YXRlICpjcnRjX3N0 YXRlLAogCSAgICAgZmItPm1vZGlmaWVyID09IEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0NDUyB8 fAogCSAgICAgZmItPm1vZGlmaWVyID09IEk5MTVfRk9STUFUX01PRF9ZZl9USUxFRF9DQ1MgfHwK IAkgICAgIGZiLT5tb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19D Q1MgfHwKLQkgICAgIGZiLT5tb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4x Ml9NQ19DQ1MpKSB7CisJICAgICBmYi0+bW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9EX1lfVElM RURfR0VOMTJfTUNfQ0NTIHx8CisJICAgICBmYi0+bW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9E X1lfVElMRURfR0VOMTJfUkNfQ0NTX0NDKSkgewogCQlEUk1fREVCVUdfS01TKCJZL1lmIHRpbGlu ZyBub3Qgc3VwcG9ydGVkIGluIElGLUlEIG1vZGVcbiIpOwogCQlyZXR1cm4gLUVJTlZBTDsKIAl9 CkBAIC0yNTU0LDYgKzI1NjAsNyBAQCBzdGF0aWMgY29uc3QgdTY0IHNrbF9wbGFuZV9mb3JtYXRf bW9kaWZpZXJzX2Njc1tdID0gewogc3RhdGljIGNvbnN0IHU2NCBnZW4xMl9wbGFuZV9mb3JtYXRf bW9kaWZpZXJzX21jX2Njc1tdID0gewogCUk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX01D X0NDUywKIAlJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1MsCisJSTkxNV9GT1JN QVRfTU9EX1lfVElMRURfR0VOMTJfUkNfQ0NTX0NDLAogCUk5MTVfRk9STUFUX01PRF9ZX1RJTEVE LAogCUk5MTVfRk9STUFUX01PRF9YX1RJTEVELAogCURSTV9GT1JNQVRfTU9EX0xJTkVBUiwKQEAg LTI1NjIsNiArMjU2OSw3IEBAIHN0YXRpYyBjb25zdCB1NjQgZ2VuMTJfcGxhbmVfZm9ybWF0X21v ZGlmaWVyc19tY19jY3NbXSA9IHsKIAogc3RhdGljIGNvbnN0IHU2NCBnZW4xMl9wbGFuZV9mb3Jt YXRfbW9kaWZpZXJzX3JjX2Njc1tdID0gewogCUk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEy X1JDX0NDUywKKwlJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0MsCiAJSTkx NV9GT1JNQVRfTU9EX1lfVElMRUQsCiAJSTkxNV9GT1JNQVRfTU9EX1hfVElMRUQsCiAJRFJNX0ZP Uk1BVF9NT0RfTElORUFSLApAQCAtMjczNyw2ICsyNzQ1LDcgQEAgc3RhdGljIGJvb2wgZ2VuMTJf cGxhbmVfZm9ybWF0X21vZF9zdXBwb3J0ZWQoc3RydWN0IGRybV9wbGFuZSAqX3BsYW5lLAogCWNh c2UgSTkxNV9GT1JNQVRfTU9EX1hfVElMRUQ6CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxF RDoKIAljYXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDUzoKKwljYXNlIEk5 MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDU19DQzoKIAkJYnJlYWs7CiAJZGVmYXVs dDoKIAkJcmV0dXJuIGZhbHNlOwpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkx NV9yZWcuaCBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfcmVnLmgKaW5kZXggNzVjY2NkNDk4 YjQyLi44YTI0NzA3ZWE2OTcgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVf cmVnLmgKKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9yZWcuaApAQCAtNjc1Myw2ICs2 NzUzLDggQEAgZW51bSB7CiAjZGVmaW5lIF9QTEFORV9LRVlNQVhfMV9BCQkJMHg3MDFhMAogI2Rl ZmluZSBfUExBTkVfS0VZTUFYXzJfQQkJCTB4NzAyYTAKICNkZWZpbmUgIFBMQU5FX0tFWU1BWF9B TFBIQShhKQkJCSgoYSkgPDwgMjQpCisjZGVmaW5lIF9QTEFORV9DQ19WQUxfMV9BCQkJMHg3MDFi NAorI2RlZmluZSBfUExBTkVfQ0NfVkFMXzJfQQkJCTB4NzAyYjQKICNkZWZpbmUgX1BMQU5FX0FV WF9ESVNUXzFfQQkJCTB4NzAxYzAKICNkZWZpbmUgX1BMQU5FX0FVWF9ESVNUXzJfQQkJCTB4NzAy YzAKICNkZWZpbmUgX1BMQU5FX0FVWF9PRkZTRVRfMV9BCQkJMHg3MDFjNApAQCAtNjc5Miw2ICs2 Nzk0LDE2IEBAIGVudW0gewogI2RlZmluZSBfUExBTkVfTlYxMl9CVUZfQ0ZHXzFfQQkJMHg3MDI3 OAogI2RlZmluZSBfUExBTkVfTlYxMl9CVUZfQ0ZHXzJfQQkJMHg3MDM3OAogCisjZGVmaW5lIF9Q TEFORV9DQ19WQUxfMV9CCQkJMHg3MTFiNAorI2RlZmluZSBfUExBTkVfQ0NfVkFMXzJfQgkJCTB4 NzEyYjQKKyNkZWZpbmUgX1BMQU5FX0NDX1ZBTF8xKHBpcGUpCV9QSVBFKHBpcGUsIF9QTEFORV9D Q19WQUxfMV9BLCBfUExBTkVfQ0NfVkFMXzFfQikKKyNkZWZpbmUgX1BMQU5FX0NDX1ZBTF8yKHBp cGUpCV9QSVBFKHBpcGUsIF9QTEFORV9DQ19WQUxfMl9BLCBfUExBTkVfQ0NfVkFMXzJfQikKKyNk ZWZpbmUgUExBTkVfQ0NfVkFMKHBpcGUsIHBsYW5lKQlcCisJX01NSU9fUExBTkUocGxhbmUsIF9Q TEFORV9DQ19WQUxfMShwaXBlKSwgX1BMQU5FX0NDX1ZBTF8yKHBpcGUpKQorCisjZGVmaW5lIEND X1ZBTF9MT1dFUl9PRkZTRVQJCTQKKyNkZWZpbmUgQ0NfVkFMX0hJR0hFUl9PRkZTRVQJCTUKKwog LyogSW5wdXQgQ1NDIFJlZ2lzdGVyIERlZmluaXRpb25zICovCiAjZGVmaW5lIF9QTEFORV9JTlBV VF9DU0NfUllfR1lfMV9BCTB4NzAxRTAKICNkZWZpbmUgX1BMQU5FX0lOUFVUX0NTQ19SWV9HWV8y X0EJMHg3MDJFMAotLSAKMi4yMC4xCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fXwpJbnRlbC1nZnggbWFpbGluZyBsaXN0CkludGVsLWdmeEBsaXN0cy5mcmVl ZGVza3RvcC5vcmcKaHR0cHM6Ly9saXN0cy5mcmVlZGVza3RvcC5vcmcvbWFpbG1hbi9saXN0aW5m by9pbnRlbC1nZng= 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 X-Spam-Level: X-Spam-Status: No, score=-9.7 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id E6384CA9EC2 for ; Mon, 28 Oct 2019 18:56:43 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id CE2232054F for ; Mon, 28 Oct 2019 18:56:43 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org CE2232054F Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=intel.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=intel-gfx-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 531886E9D2; Mon, 28 Oct 2019 18:56:43 +0000 (UTC) Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by gabe.freedesktop.org (Postfix) with ESMTPS id 10EF76E9D2 for ; Mon, 28 Oct 2019 18:56:41 +0000 (UTC) X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Oct 2019 11:56:41 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.68,241,1569308400"; d="scan'208";a="205254887" Received: from invictus.jf.intel.com ([10.54.75.159]) by FMSMGA003.fm.intel.com with ESMTP; 28 Oct 2019 11:56:40 -0700 From: Radhakrishna Sripada To: intel-gfx@lists.freedesktop.org Date: Mon, 28 Oct 2019 11:58:35 -0700 Message-Id: <20191028185835.13004-1-radhakrishna.sripada@intel.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20191023000922.32247-1-radhakrishna.sripada@intel.com> References: <20191023000922.32247-1-radhakrishna.sripada@intel.com> MIME-Version: 1.0 Subject: [Intel-gfx] [PATCH v6 10/10] drm/i915/tgl: Add Clear Color supoort for TGL Render Decompression X-BeenThere: intel-gfx@lists.freedesktop.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Intel graphics driver community testing & development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Nanley G Chery , Dhinakaran Pandiyan , Ville Syrjala Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" Message-ID: <20191028185835.ouy_zkoa8h4JTbWzuUFSNZ779l7MEylL5eZWM0bbOlQ@z> UmVuZGVyIERlY29tcHJlc3Npb24gaXMgc3VwcG9ydGVkIHdpdGggWS1UaWxlZCBtYWluIHN1cmZh Y2UuIFRoZSBDQ1MgaXMKbGluZWFyIGFuZCBoYXMgNCBiaXRzIG9mIGRhdGEgZm9yIGVhY2ggbWFp biBzdXJmYWNlIGNhY2hlIGxpbmUgcGFpciwgYQpyYXRpbyBvZiAxOjI1Ni4gQWRkaXRpb25hbCBD bGVhciBDb2xvciBpbmZvcm1hdGlvbiBpcyBwYXNzZWQgZnJvbSB0aGUKdXNlci1zcGFjZSB0aHJv dWdoIGFuIG9mZnNldCBpbiB0aGUgR0VNIEJPLiBBZGQgYSBuZXcgbW9kaWZpZXIgdG8gaWRlbnRp ZnkKYW5kIHBhcnNlIG5ldyBDbGVhciBDb2xvciBpbmZvcm1hdGlvbiBhbmQgZXh0ZW5kIEdlbjEy IHJlbmRlciBkZWNvbXByZXNzaW9uCmZ1bmN0aW9uYWxpdHkgdG8gdGhlIG5ld2x5IGFkZGVkIG1v ZGlmaWVyLgoKdjI6IEZpeCBoYXNfYWxwaGEgZmxhZyBmb3IgbW9kaWZpZXJzLCBvbWl0IENDIG1v ZGlmaWVyIGR1cmluZyBpbml0aWFsCiAgICBwbGFuZSBjb25maWcoTWF0dCkuIEZpeCBMb29rdXAg ZXJyb3IuCnYzOiBGaXggdGhlIHBhbmljIHdoaWxlIHJ1bm5pbmcga21zX2N1YmUKdjQ6IEFkZCBh bGlnbm1lbnQgY2hlY2sgYW5kIHJldXNlIHRoZSBjb21tZW50cyBmb3IgZ2UxMl9jY3NfZm9ybWF0 cyhNYXR0KQp2NTogRml4IHR5cG9zIGFuZCB3cmFwIGNvbW1lbnRzKE1hdHQpCgpDYzogRGhpbmFr YXJhbiBQYW5kaXlhbiA8ZGhpbmFrYXJhbi5wYW5kaXlhbkBpbnRlbC5jb20+CkNjOiBWaWxsZSBT eXJqYWxhIDx2aWxsZS5zeXJqYWxhQGludGVsLmNvbT4KQ2M6IFNoYXNoYW5rIFNoYXJtYSA8c2hh c2hhbmsuc2hhcm1hQGludGVsLmNvbT4KQ2M6IFJhZmFlbCBBbnRvZ25vbGxpIDxyYWZhZWwuYW50 b2dub2xsaUBpbnRlbC5jb20+CkNjOiBOYW5sZXkgRyBDaGVyeSA8bmFubGV5LmcuY2hlcnlAaW50 ZWwuY29tPgpSZXZpZXdlZC1ieTogTWF0dCBSb3BlciA8bWF0dGhldy5kLnJvcGVyQGludGVsLmNv bT4KU2lnbmVkLW9mZi1ieTogUmFkaGFrcmlzaG5hIFNyaXBhZGEgPHJhZGhha3Jpc2huYS5zcmlw YWRhQGludGVsLmNvbT4KLS0tCiBkcml2ZXJzL2dwdS9kcm0vaTkxNS9kaXNwbGF5L2ludGVsX2Rp c3BsYXkuYyAgfCA1MiArKysrKysrKysrKysrKysrKysrCiAuLi4vZHJtL2k5MTUvZGlzcGxheS9p bnRlbF9kaXNwbGF5X3R5cGVzLmggICAgfCAgMyArKwogZHJpdmVycy9ncHUvZHJtL2k5MTUvZGlz cGxheS9pbnRlbF9zcHJpdGUuYyAgIHwgMTEgKysrLQogZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkx NV9yZWcuaCAgICAgICAgICAgICAgIHwgMTIgKysrKysKIDQgZmlsZXMgY2hhbmdlZCwgNzcgaW5z ZXJ0aW9ucygrKSwgMSBkZWxldGlvbigtKQoKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9p OTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheS5jIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvZGlzcGxh eS9pbnRlbF9kaXNwbGF5LmMKaW5kZXggMjBhZDA4OWRhNmVlLi42ZDZlYWI4ZDQ3NzYgMTAwNjQ0 Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheS5jCisrKyBi L2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheS5jCkBAIC0xOTQ0LDYg KzE5NDQsMTAgQEAgaW50ZWxfdGlsZV93aWR0aF9ieXRlcyhjb25zdCBzdHJ1Y3QgZHJtX2ZyYW1l YnVmZmVyICpmYiwgaW50IGNvbG9yX3BsYW5lKQogCQlpZiAoY29sb3JfcGxhbmUgPT0gMSkKIAkJ CXJldHVybiA2NDsKIAkJLyogZmFsbCB0aHJvdWdoICovCisJY2FzZSBJOTE1X0ZPUk1BVF9NT0Rf WV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0M6CisJCWlmIChjb2xvcl9wbGFuZSA9PSAxIHx8IGNvbG9y X3BsYW5lID09IDIpCisJCQlyZXR1cm4gNjQ7CisJCS8qIGZhbGwgdGhyb3VnaCAqLwogCWNhc2Ug STkxNV9GT1JNQVRfTU9EX1lfVElMRUQ6CiAJCWlmIChJU19HRU4oZGV2X3ByaXYsIDIpIHx8IEhB U18xMjhfQllURV9ZX1RJTElORyhkZXZfcHJpdikpCiAJCQlyZXR1cm4gMTI4OwpAQCAtMjA4NSw2 ICsyMDg5LDcgQEAgc3RhdGljIHVuc2lnbmVkIGludCBpbnRlbF9zdXJmX2FsaWdubWVudChjb25z dCBzdHJ1Y3QgZHJtX2ZyYW1lYnVmZmVyICpmYiwKIAkJCXJldHVybiAyNTYgKiAxMDI0OwogCQly ZXR1cm4gMDsKIAljYXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDUzoKKwlj YXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDU19DQzoKIAkJcmV0dXJuIDE2 ICogMTAyNDsKIAljYXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0NDUzoKIAljYXNlIEk5MTVf Rk9STUFUX01PRF9ZZl9USUxFRF9DQ1M6CkBAIC0yMjg3LDYgKzIyOTIsOCBAQCBzdGF0aWMgYm9v bCBpc19zdXJmYWNlX2xpbmVhcih1NjQgbW9kaWZpZXIsIGludCBjb2xvcl9wbGFuZSkKIAkJcmV0 dXJuIHRydWU7CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1M6CiAJ CXJldHVybiBjb2xvcl9wbGFuZSA9PSAxOworCWNhc2UgSTkxNV9GT1JNQVRfTU9EX1lfVElMRURf R0VOMTJfUkNfQ0NTX0NDOgorCQlyZXR1cm4gY29sb3JfcGxhbmUgPT0gMSB8fCBjb2xvcl9wbGFu ZSA9PSAyOwogCWNhc2UgSTkxNV9GT1JNQVRfTU9EX1lfVElMRURfR0VOMTJfTUNfQ0NTOgogCQly ZXR1cm4gY29sb3JfcGxhbmUgPT0gMSB8fCBjb2xvcl9wbGFuZSA9PSAzOwogCWRlZmF1bHQ6CkBA IC0yNDgwLDYgKzI0ODcsNyBAQCBzdGF0aWMgdW5zaWduZWQgaW50IGludGVsX2ZiX21vZGlmaWVy X3RvX3RpbGluZyh1NjQgZmJfbW9kaWZpZXIpCiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxF RF9DQ1M6CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1M6CiAJY2Fz ZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9NQ19DQ1M6CisJY2FzZSBJOTE1X0ZPUk1B VF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0M6CiAJCXJldHVybiBJOTE1X1RJTElOR19ZOwog CWRlZmF1bHQ6CiAJCXJldHVybiBJOTE1X1RJTElOR19OT05FOwpAQCAtMjUzMyw2ICsyNTQxLDIx IEBAIHN0YXRpYyBjb25zdCBzdHJ1Y3QgZHJtX2Zvcm1hdF9pbmZvIGdlbjEyX2Njc19mb3JtYXRz W10gPSB7CiAJICAuY3BwID0geyAxLCAxLCAyLCAxfSwgLmhzdWIgPSAyLCAudnN1YiA9IDIsIC5p c195dXYgPSB0cnVlIH0sCiB9OwogCisvKgorICogU2FtZSBhcyBnZW4xMl9jY3NfZm9ybWF0c1td IGFib3ZlLCBidXQgd2l0aCBhZGRpdGlvbmFsIHN1cmZhY2UgdXNlZAorICogdG8gcGFzcyBDbGVh ciBDb2xvciBpbmZvcm1hdGlvbiBpbiBwbGFuZSAyIHdpdGggNjQgYml0cyBvZiBkYXRhLgorICov CitzdGF0aWMgY29uc3Qgc3RydWN0IGRybV9mb3JtYXRfaW5mbyBnZW4xMl9jY3NfY2NfZm9ybWF0 c1tdID0geworCXsgLmZvcm1hdCA9IERSTV9GT1JNQVRfWFJHQjg4ODgsIC5kZXB0aCA9IDI0LCAu bnVtX3BsYW5lcyA9IDMsCisJICAuY3BwID0geyA0LCAxLCAwLCB9LCAuaHN1YiA9IDIsIC52c3Vi ID0gMzIsIH0sCisJeyAuZm9ybWF0ID0gRFJNX0ZPUk1BVF9YQkdSODg4OCwgLmRlcHRoID0gMjQs IC5udW1fcGxhbmVzID0gMywKKwkgIC5jcHAgPSB7IDQsIDEsIDAsIH0sIC5oc3ViID0gMiwgLnZz dWIgPSAzMiwgfSwKKwl7IC5mb3JtYXQgPSBEUk1fRk9STUFUX0FSR0I4ODg4LCAuZGVwdGggPSAz MiwgLm51bV9wbGFuZXMgPSAzLAorCSAgLmNwcCA9IHsgNCwgMSwgMCwgfSwgLmhzdWIgPSAyLCAu dnN1YiA9IDMyLCAuaGFzX2FscGhhID0gdHJ1ZSB9LAorCXsgLmZvcm1hdCA9IERSTV9GT1JNQVRf QUJHUjg4ODgsIC5kZXB0aCA9IDMyLCAubnVtX3BsYW5lcyA9IDMsCisJICAuY3BwID0geyA0LCAx LCAwLCB9LCAuaHN1YiA9IDIsIC52c3ViID0gMzIsIC5oYXNfYWxwaGEgPSB0cnVlIH0sCit9Owor CiBzdGF0aWMgY29uc3Qgc3RydWN0IGRybV9mb3JtYXRfaW5mbyAqCiBsb29rdXBfZm9ybWF0X2lu Zm8oY29uc3Qgc3RydWN0IGRybV9mb3JtYXRfaW5mbyBmb3JtYXRzW10sCiAJCSAgIGludCBudW1f Zm9ybWF0cywgdTMyIGZvcm1hdCkKQEAgLTI1NjAsNiArMjU4MywxMCBAQCBpbnRlbF9nZXRfZm9y bWF0X2luZm8oY29uc3Qgc3RydWN0IGRybV9tb2RlX2ZiX2NtZDIgKmNtZCkKIAkJcmV0dXJuIGxv b2t1cF9mb3JtYXRfaW5mbyhnZW4xMl9jY3NfZm9ybWF0cywKIAkJCQkJICBBUlJBWV9TSVpFKGdl bjEyX2Njc19mb3JtYXRzKSwKIAkJCQkJICBjbWQtPnBpeGVsX2Zvcm1hdCk7CisJY2FzZSBJOTE1 X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0M6CisJCXJldHVybiBsb29rdXBfZm9y bWF0X2luZm8oZ2VuMTJfY2NzX2NjX2Zvcm1hdHMsCisJCQkJCSAgQVJSQVlfU0laRShnZW4xMl9j Y3NfY2NfZm9ybWF0cyksCisJCQkJCSAgY21kLT5waXhlbF9mb3JtYXQpOwogCWRlZmF1bHQ6CiAJ CXJldHVybiBOVUxMOwogCX0KQEAgLTI1NjksNiArMjU5Niw3IEBAIGJvb2wgaXNfY2NzX21vZGlm aWVyKHU2NCBtb2RpZmllcikKIHsKIAlyZXR1cm4gbW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9E X1lfVElMRURfR0VOMTJfUkNfQ0NTIHx8CiAJICAgICAgIG1vZGlmaWVyID09IEk5MTVfRk9STUFU X01PRF9ZX1RJTEVEX0dFTjEyX01DX0NDUyB8fAorCSAgICAgICBtb2RpZmllciA9PSBJOTE1X0ZP Uk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0MgfHwKIAkgICAgICAgbW9kaWZpZXIgPT0g STkxNV9GT1JNQVRfTU9EX1lfVElMRURfQ0NTIHx8CiAJICAgICAgIG1vZGlmaWVyID09IEk5MTVf Rk9STUFUX01PRF9ZZl9USUxFRF9DQ1M7CiB9CkBAIC0yNzU2LDYgKzI3ODQsOCBAQCBzdGF0aWMg Ym9vbCBpc19jY3NfcGxhbmUodTY0IG1vZGlmaWVyLCBpbnQgY29sb3JfcGxhbmUpCiAJCXJldHVy biBmYWxzZTsKIAllbHNlIGlmIChtb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9H RU4xMl9NQ19DQ1MpCiAJCXJldHVybiBjb2xvcl9wbGFuZSA9PSAzIHx8IGNvbG9yX3BsYW5lID09 IDE7CisJZWxzZSBpZiAobW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9EX1lfVElMRURfR0VOMTJf UkNfQ0NTX0NDKQorCQlyZXR1cm4gY29sb3JfcGxhbmUgPT0gMSB8fCBjb2xvcl9wbGFuZSA9PSAy OwogCWVsc2UKIAkJcmV0dXJuIGNvbG9yX3BsYW5lID09IDE7CiB9CkBAIC0yODI0LDYgKzI4NTQs MTggQEAgaW50ZWxfZmlsbF9mYl9pbmZvKHN0cnVjdCBkcm1faTkxNV9wcml2YXRlICpkZXZfcHJp diwKIAkJaW50IHgsIHk7CiAJCWludCByZXQ7CiAKKwkJLyoKKwkJICogUGxhbmUgMiBvZiBSZW5k ZXIgQ29tcHJlc3Npb24gd2l0aCBDbGVhciBDb2xvciBmYiBtb2RpZmllcgorCQkgKiBpcyBjb25z dW1lZCBieSB0aGUgZHJpdmVyIGFuZCBub3QgcGFzc2VkIHRvIERFLiBTa2lwIHRoZQorCQkgKiBh cml0aG1ldGljIHJlbGF0ZWQgdG8gYWxpZ25tZW50IGFuZCBvZmZzZXQgY2FsY3VsYXRpb24uCisJ CSAqLworCQlpZiAoaSA9PSAyICYmIGZiLT5tb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9U SUxFRF9HRU4xMl9SQ19DQ1NfQ0MpIHsKKwkJCWlmIChJU19BTElHTkVEKGZiLT5vZmZzZXRzWzJd LCBQQUdFX1NJWkUpKQorCQkJCWNvbnRpbnVlOworCQkJZWxzZQorCQkJCXJldHVybiAtRUlOVkFM OworCQl9CisKIAkJY3BwID0gZmItPmZvcm1hdC0+Y3BwW2ldOwogCQlpbnRlbF9mYl9wbGFuZV9k aW1zKCZ3aWR0aCwgJmhlaWdodCwgZmIsIGkpOwogCkBAIC00MzQxLDYgKzQzODMsNyBAQCBzdGF0 aWMgdTMyIHNrbF9wbGFuZV9jdGxfdGlsaW5nKHU2NCBmYl9tb2RpZmllcikKIAljYXNlIEk5MTVf Rk9STUFUX01PRF9ZX1RJTEVEOgogCQlyZXR1cm4gUExBTkVfQ1RMX1RJTEVEX1k7CiAJY2FzZSBJ OTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9DQ1M6CisJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxF RF9HRU4xMl9SQ19DQ1NfQ0M6CiAJCXJldHVybiBQTEFORV9DVExfVElMRURfWSB8IFBMQU5FX0NU TF9SRU5ERVJfREVDT01QUkVTU0lPTl9FTkFCTEU7CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9U SUxFRF9HRU4xMl9SQ19DQ1M6CiAJCXJldHVybiBQTEFORV9DVExfVElMRURfWSB8CkBAIC0xNTIx Miw2ICsxNTI1NSwxNSBAQCBzdGF0aWMgaW50IGludGVsX3BsYW5lX3Bpbl9mYihzdHJ1Y3QgaW50 ZWxfcGxhbmVfc3RhdGUgKnBsYW5lX3N0YXRlKQogCiAJcGxhbmVfc3RhdGUtPnZtYSA9IHZtYTsK IAorCWlmIChmYi0+bW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9EX1lfVElMRURfR0VOMTJfUkNf Q0NTX0NDKSB7CisJCXUzMiAqY2NhZGRyID0ga21hcF9hdG9taWMoaTkxNV9nZW1fb2JqZWN0X2dl dF9wYWdlKGludGVsX2ZiX29iaihmYiksCisJCQkJCQkJCSAgZmItPm9mZnNldHNbMl0gPj4gUEFH RV9TSElGVCkpOworCisJCXBsYW5lX3N0YXRlLT5jY3ZhbCA9ICgodTY0KSooY2NhZGRyICsgQ0Nf VkFMX0hJR0hFUl9PRkZTRVQpIDw8IDMyKQorCQkJCSAgICAgfCAqKGNjYWRkciArIENDX1ZBTF9M T1dFUl9PRkZTRVQpOworCQlrdW5tYXBfYXRvbWljKGNjYWRkcik7CisJfQorCiAJcmV0dXJuIDA7 CiB9CiAKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlz cGxheV90eXBlcy5oIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvZGlzcGxheS9pbnRlbF9kaXNwbGF5 X3R5cGVzLmgKaW5kZXggZTk4ZjIxMjY4MmY2Li45ZTE0N2JiYTA5MmUgMTAwNjQ0Ci0tLSBhL2Ry aXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheV90eXBlcy5oCisrKyBiL2Ry aXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkvaW50ZWxfZGlzcGxheV90eXBlcy5oCkBAIC01ODcs NiArNTg3LDkgQEAgc3RydWN0IGludGVsX3BsYW5lX3N0YXRlIHsKIAl1MzIgcGxhbmFyX3NsYXZl OwogCiAJc3RydWN0IGRybV9pbnRlbF9zcHJpdGVfY29sb3JrZXkgY2tleTsKKworCS8qIENsZWFy IENvbG9yIFZhbHVlICovCisJdTY0IGNjdmFsOwogfTsKIAogc3RydWN0IGludGVsX2luaXRpYWxf cGxhbmVfY29uZmlnIHsKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2Rpc3BsYXkv aW50ZWxfc3ByaXRlLmMgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9kaXNwbGF5L2ludGVsX3Nwcml0 ZS5jCmluZGV4IGE1MDE4ZmZmYThmMi4uZjhkMjk4NWU2YzAxIDEwMDY0NAotLS0gYS9kcml2ZXJz L2dwdS9kcm0vaTkxNS9kaXNwbGF5L2ludGVsX3Nwcml0ZS5jCisrKyBiL2RyaXZlcnMvZ3B1L2Ry bS9pOTE1L2Rpc3BsYXkvaW50ZWxfc3ByaXRlLmMKQEAgLTU5Niw2ICs1OTYsNyBAQCBza2xfcHJv Z3JhbV9wbGFuZShzdHJ1Y3QgaW50ZWxfcGxhbmUgKnBsYW5lLAogCXUzMiBwbGFuZV9jb2xvcl9j dGwgPSAwOwogCXVuc2lnbmVkIGxvbmcgaXJxZmxhZ3M7CiAJdTMyIGtleW1zaywga2V5bWF4Owor CXU2NCBjY3ZhbCA9IHBsYW5lX3N0YXRlLT5jY3ZhbDsKIAogCXBsYW5lX2N0bCB8PSBza2xfcGxh bmVfY3RsX2NydGMoY3J0Y19zdGF0ZSk7CiAKQEAgLTY1Niw2ICs2NTcsMTAgQEAgc2tsX3Byb2dy YW1fcGxhbmUoc3RydWN0IGludGVsX3BsYW5lICpwbGFuZSwKIAlpZiAoZmItPmZvcm1hdC0+aXNf eXV2ICYmIGljbF9pc19oZHJfcGxhbmUoZGV2X3ByaXYsIHBsYW5lX2lkKSkKIAkJaWNsX3Byb2dy YW1faW5wdXRfY3NjKHBsYW5lLCBjcnRjX3N0YXRlLCBwbGFuZV9zdGF0ZSk7CiAKKwlpZiAoZmIt Pm1vZGlmaWVyID09IEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDU19DQykKKwkJ aW50ZWxfdW5jb3JlX3dyaXRlNjRfZncoJmRldl9wcml2LT51bmNvcmUsCisJCQkJCVBMQU5FX0ND X1ZBTChwaXBlLCBwbGFuZV9pZCksIGNjdmFsKTsKKwogCXNrbF93cml0ZV9wbGFuZV93bShwbGFu ZSwgY3J0Y19zdGF0ZSk7CiAKIAlJOTE1X1dSSVRFX0ZXKFBMQU5FX0tFWVZBTChwaXBlLCBwbGFu ZV9pZCksIGtleS0+bWluX3ZhbHVlKTsKQEAgLTIxMTUsNyArMjEyMCw4IEBAIHN0YXRpYyBpbnQg c2tsX3BsYW5lX2NoZWNrX2ZiKGNvbnN0IHN0cnVjdCBpbnRlbF9jcnRjX3N0YXRlICpjcnRjX3N0 YXRlLAogCSAgICAgZmItPm1vZGlmaWVyID09IEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0NDUyB8 fAogCSAgICAgZmItPm1vZGlmaWVyID09IEk5MTVfRk9STUFUX01PRF9ZZl9USUxFRF9DQ1MgfHwK IAkgICAgIGZiLT5tb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19D Q1MgfHwKLQkgICAgIGZiLT5tb2RpZmllciA9PSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4x Ml9NQ19DQ1MpKSB7CisJICAgICBmYi0+bW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9EX1lfVElM RURfR0VOMTJfTUNfQ0NTIHx8CisJICAgICBmYi0+bW9kaWZpZXIgPT0gSTkxNV9GT1JNQVRfTU9E X1lfVElMRURfR0VOMTJfUkNfQ0NTX0NDKSkgewogCQlEUk1fREVCVUdfS01TKCJZL1lmIHRpbGlu ZyBub3Qgc3VwcG9ydGVkIGluIElGLUlEIG1vZGVcbiIpOwogCQlyZXR1cm4gLUVJTlZBTDsKIAl9 CkBAIC0yNTU0LDYgKzI1NjAsNyBAQCBzdGF0aWMgY29uc3QgdTY0IHNrbF9wbGFuZV9mb3JtYXRf bW9kaWZpZXJzX2Njc1tdID0gewogc3RhdGljIGNvbnN0IHU2NCBnZW4xMl9wbGFuZV9mb3JtYXRf bW9kaWZpZXJzX21jX2Njc1tdID0gewogCUk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX01D X0NDUywKIAlJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1MsCisJSTkxNV9GT1JN QVRfTU9EX1lfVElMRURfR0VOMTJfUkNfQ0NTX0NDLAogCUk5MTVfRk9STUFUX01PRF9ZX1RJTEVE LAogCUk5MTVfRk9STUFUX01PRF9YX1RJTEVELAogCURSTV9GT1JNQVRfTU9EX0xJTkVBUiwKQEAg LTI1NjIsNiArMjU2OSw3IEBAIHN0YXRpYyBjb25zdCB1NjQgZ2VuMTJfcGxhbmVfZm9ybWF0X21v ZGlmaWVyc19tY19jY3NbXSA9IHsKIAogc3RhdGljIGNvbnN0IHU2NCBnZW4xMl9wbGFuZV9mb3Jt YXRfbW9kaWZpZXJzX3JjX2Njc1tdID0gewogCUk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEy X1JDX0NDUywKKwlJOTE1X0ZPUk1BVF9NT0RfWV9USUxFRF9HRU4xMl9SQ19DQ1NfQ0MsCiAJSTkx NV9GT1JNQVRfTU9EX1lfVElMRUQsCiAJSTkxNV9GT1JNQVRfTU9EX1hfVElMRUQsCiAJRFJNX0ZP Uk1BVF9NT0RfTElORUFSLApAQCAtMjczNyw2ICsyNzQ1LDcgQEAgc3RhdGljIGJvb2wgZ2VuMTJf cGxhbmVfZm9ybWF0X21vZF9zdXBwb3J0ZWQoc3RydWN0IGRybV9wbGFuZSAqX3BsYW5lLAogCWNh c2UgSTkxNV9GT1JNQVRfTU9EX1hfVElMRUQ6CiAJY2FzZSBJOTE1X0ZPUk1BVF9NT0RfWV9USUxF RDoKIAljYXNlIEk5MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDUzoKKwljYXNlIEk5 MTVfRk9STUFUX01PRF9ZX1RJTEVEX0dFTjEyX1JDX0NDU19DQzoKIAkJYnJlYWs7CiAJZGVmYXVs dDoKIAkJcmV0dXJuIGZhbHNlOwpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkx NV9yZWcuaCBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfcmVnLmgKaW5kZXggNzVjY2NkNDk4 YjQyLi44YTI0NzA3ZWE2OTcgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVf cmVnLmgKKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9yZWcuaApAQCAtNjc1Myw2ICs2 NzUzLDggQEAgZW51bSB7CiAjZGVmaW5lIF9QTEFORV9LRVlNQVhfMV9BCQkJMHg3MDFhMAogI2Rl ZmluZSBfUExBTkVfS0VZTUFYXzJfQQkJCTB4NzAyYTAKICNkZWZpbmUgIFBMQU5FX0tFWU1BWF9B TFBIQShhKQkJCSgoYSkgPDwgMjQpCisjZGVmaW5lIF9QTEFORV9DQ19WQUxfMV9BCQkJMHg3MDFi NAorI2RlZmluZSBfUExBTkVfQ0NfVkFMXzJfQQkJCTB4NzAyYjQKICNkZWZpbmUgX1BMQU5FX0FV WF9ESVNUXzFfQQkJCTB4NzAxYzAKICNkZWZpbmUgX1BMQU5FX0FVWF9ESVNUXzJfQQkJCTB4NzAy YzAKICNkZWZpbmUgX1BMQU5FX0FVWF9PRkZTRVRfMV9BCQkJMHg3MDFjNApAQCAtNjc5Miw2ICs2 Nzk0LDE2IEBAIGVudW0gewogI2RlZmluZSBfUExBTkVfTlYxMl9CVUZfQ0ZHXzFfQQkJMHg3MDI3 OAogI2RlZmluZSBfUExBTkVfTlYxMl9CVUZfQ0ZHXzJfQQkJMHg3MDM3OAogCisjZGVmaW5lIF9Q TEFORV9DQ19WQUxfMV9CCQkJMHg3MTFiNAorI2RlZmluZSBfUExBTkVfQ0NfVkFMXzJfQgkJCTB4 NzEyYjQKKyNkZWZpbmUgX1BMQU5FX0NDX1ZBTF8xKHBpcGUpCV9QSVBFKHBpcGUsIF9QTEFORV9D Q19WQUxfMV9BLCBfUExBTkVfQ0NfVkFMXzFfQikKKyNkZWZpbmUgX1BMQU5FX0NDX1ZBTF8yKHBp cGUpCV9QSVBFKHBpcGUsIF9QTEFORV9DQ19WQUxfMl9BLCBfUExBTkVfQ0NfVkFMXzJfQikKKyNk ZWZpbmUgUExBTkVfQ0NfVkFMKHBpcGUsIHBsYW5lKQlcCisJX01NSU9fUExBTkUocGxhbmUsIF9Q TEFORV9DQ19WQUxfMShwaXBlKSwgX1BMQU5FX0NDX1ZBTF8yKHBpcGUpKQorCisjZGVmaW5lIEND X1ZBTF9MT1dFUl9PRkZTRVQJCTQKKyNkZWZpbmUgQ0NfVkFMX0hJR0hFUl9PRkZTRVQJCTUKKwog LyogSW5wdXQgQ1NDIFJlZ2lzdGVyIERlZmluaXRpb25zICovCiAjZGVmaW5lIF9QTEFORV9JTlBV VF9DU0NfUllfR1lfMV9BCTB4NzAxRTAKICNkZWZpbmUgX1BMQU5FX0lOUFVUX0NTQ19SWV9HWV8y X0EJMHg3MDJFMAotLSAKMi4yMC4xCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fXwpJbnRlbC1nZnggbWFpbGluZyBsaXN0CkludGVsLWdmeEBsaXN0cy5mcmVl ZGVza3RvcC5vcmcKaHR0cHM6Ly9saXN0cy5mcmVlZGVza3RvcC5vcmcvbWFpbG1hbi9saXN0aW5m by9pbnRlbC1nZng=