From mboxrd@z Thu Jan 1 00:00:00 1970 From: Chris Wilson Subject: [PATCH 05/17] drm/i915: Reorder submitting the requests to ELSP Date: Sun, 28 Aug 2016 21:46:12 +0100 Message-ID: <20160828204624.21193-6-chris@chris-wilson.co.uk> References: <20160828204624.21193-1-chris@chris-wilson.co.uk> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mail-wm0-x243.google.com (mail-wm0-x243.google.com [IPv6:2a00:1450:400c:c09::243]) by gabe.freedesktop.org (Postfix) with ESMTPS id 857EF6E219 for ; Sun, 28 Aug 2016 20:46:37 +0000 (UTC) Received: by mail-wm0-x243.google.com with SMTP id i5so7031388wmg.2 for ; Sun, 28 Aug 2016 13:46:37 -0700 (PDT) In-Reply-To: <20160828204624.21193-1-chris@chris-wilson.co.uk> 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: mika.kuoppala@intel.com List-Id: intel-gfx@lists.freedesktop.org SnVzdCByZWFycmFuZ2UgdGhlIGNvZGUgdG8gcmVkdWNlIGNodXJuIGluIHRoZSBuZXh0IHBhdGNo LgoKU2lnbmVkLW9mZi1ieTogQ2hyaXMgV2lsc29uIDxjaHJpc0BjaHJpcy13aWxzb24uY28udWs+ ClJldmlld2VkLWJ5OiBNaWthIEt1b3BwYWxhIDxtaWthLmt1b3BwYWxhQGludGVsLmNvbT4KLS0t CiBkcml2ZXJzL2dwdS9kcm0vaTkxNS9pbnRlbF9scmMuYyB8IDc2ICsrKysrKysrKysrKysrKysr KysrLS0tLS0tLS0tLS0tLS0tLS0tLS0KIDEgZmlsZSBjaGFuZ2VkLCAzOCBpbnNlcnRpb25zKCsp LCAzOCBkZWxldGlvbnMoLSkKCmRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pbnRl bF9scmMuYyBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2xyYy5jCmluZGV4IDgzMWE1YWE3 NjliMi4uZTljYjRhOTA2MDA5IDEwMDY0NAotLS0gYS9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pbnRl bF9scmMuYworKysgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pbnRlbF9scmMuYwpAQCAtMzI4LDMy ICszMjgsMTggQEAgdWludDY0X3QgaW50ZWxfbHJfY29udGV4dF9kZXNjcmlwdG9yKHN0cnVjdCBp OTE1X2dlbV9jb250ZXh0ICpjdHgsCiAJcmV0dXJuIGN0eC0+ZW5naW5lW2VuZ2luZS0+aWRdLmxy Y19kZXNjOwogfQogCi1zdGF0aWMgdm9pZCBleGVjbGlzdHNfZWxzcF93cml0ZShzdHJ1Y3QgZHJt X2k5MTVfZ2VtX3JlcXVlc3QgKnJxMCwKLQkJCQkgc3RydWN0IGRybV9pOTE1X2dlbV9yZXF1ZXN0 ICpycTEpCitzdGF0aWMgaW5saW5lIHZvaWQKK2V4ZWNsaXN0c19jb250ZXh0X3N0YXR1c19jaGFu Z2Uoc3RydWN0IGRybV9pOTE1X2dlbV9yZXF1ZXN0ICpycSwKKwkJCQl1bnNpZ25lZCBsb25nIHN0 YXR1cykKIHsKLQlzdHJ1Y3QgaW50ZWxfZW5naW5lX2NzICplbmdpbmUgPSBycTAtPmVuZ2luZTsK LQlzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqZGV2X3ByaXYgPSBycTAtPmk5MTU7Ci0JdTMyIF9f aW9tZW0gKmVsc3AgPQotCQlkZXZfcHJpdi0+cmVncyArIGk5MTVfbW1pb19yZWdfb2Zmc2V0KFJJ TkdfRUxTUChlbmdpbmUpKTsKLQl1NjQgZGVzY1syXTsKLQotCWlmIChycTEpIHsKLQkJZGVzY1sx XSA9IGludGVsX2xyX2NvbnRleHRfZGVzY3JpcHRvcihycTEtPmN0eCwgcnExLT5lbmdpbmUpOwot CQlycTEtPmVsc3Bfc3VibWl0dGVkKys7Ci0JfSBlbHNlIHsKLQkJZGVzY1sxXSA9IDA7Ci0JfQot Ci0JZGVzY1swXSA9IGludGVsX2xyX2NvbnRleHRfZGVzY3JpcHRvcihycTAtPmN0eCwgcnEwLT5l bmdpbmUpOwotCXJxMC0+ZWxzcF9zdWJtaXR0ZWQrKzsKLQotCS8qIFlvdSBtdXN0IGFsd2F5cyB3 cml0ZSBib3RoIGRlc2NyaXB0b3JzIGluIHRoZSBvcmRlciBiZWxvdy4gKi8KLQl3cml0ZWwodXBw ZXJfMzJfYml0cyhkZXNjWzFdKSwgZWxzcCk7Ci0Jd3JpdGVsKGxvd2VyXzMyX2JpdHMoZGVzY1sx XSksIGVsc3ApOworCS8qCisJICogT25seSB1c2VkIHdoZW4gR1ZULWcgaXMgZW5hYmxlZCBub3cu IFdoZW4gR1ZULWcgaXMgZGlzYWJsZWQsCisJICogVGhlIGNvbXBpbGVyIHNob3VsZCBlbGltaW5h dGUgdGhpcyBmdW5jdGlvbiBhcyBkZWFkLWNvZGUuCisJICovCisJaWYgKCFJU19FTkFCTEVEKENP TkZJR19EUk1fSTkxNV9HVlQpKQorCQlyZXR1cm47CiAKLQl3cml0ZWwodXBwZXJfMzJfYml0cyhk ZXNjWzBdKSwgZWxzcCk7Ci0JLyogVGhlIGNvbnRleHQgaXMgYXV0b21hdGljYWxseSBsb2FkZWQg YWZ0ZXIgdGhlIGZvbGxvd2luZyAqLwotCXdyaXRlbChsb3dlcl8zMl9iaXRzKGRlc2NbMF0pLCBl bHNwKTsKKwlhdG9taWNfbm90aWZpZXJfY2FsbF9jaGFpbigmcnEtPmN0eC0+c3RhdHVzX25vdGlm aWVyLCBzdGF0dXMsIHJxKTsKIH0KIAogc3RhdGljIHZvaWQKQEAgLTM4Miw2ICszNjgsMzQgQEAg c3RhdGljIHZvaWQgZXhlY2xpc3RzX3VwZGF0ZV9jb250ZXh0KHN0cnVjdCBkcm1faTkxNV9nZW1f cmVxdWVzdCAqcnEpCiAJCWV4ZWNsaXN0c191cGRhdGVfY29udGV4dF9wZHBzKHBwZ3R0LCByZWdf c3RhdGUpOwogfQogCitzdGF0aWMgdm9pZCBleGVjbGlzdHNfZWxzcF93cml0ZShzdHJ1Y3QgZHJt X2k5MTVfZ2VtX3JlcXVlc3QgKnJxMCwKKwkJCQkgc3RydWN0IGRybV9pOTE1X2dlbV9yZXF1ZXN0 ICpycTEpCit7CisJc3RydWN0IGludGVsX2VuZ2luZV9jcyAqZW5naW5lID0gcnEwLT5lbmdpbmU7 CisJc3RydWN0IGRybV9pOTE1X3ByaXZhdGUgKmRldl9wcml2ID0gcnEwLT5pOTE1OworCXUzMiBf X2lvbWVtICplbHNwID0KKwkJZGV2X3ByaXYtPnJlZ3MgKyBpOTE1X21taW9fcmVnX29mZnNldChS SU5HX0VMU1AoZW5naW5lKSk7CisJdTY0IGRlc2NbMl07CisKKwlpZiAocnExKSB7CisJCWRlc2Nb MV0gPSBpbnRlbF9scl9jb250ZXh0X2Rlc2NyaXB0b3IocnExLT5jdHgsIHJxMS0+ZW5naW5lKTsK KwkJcnExLT5lbHNwX3N1Ym1pdHRlZCsrOworCX0gZWxzZSB7CisJCWRlc2NbMV0gPSAwOworCX0K KworCWRlc2NbMF0gPSBpbnRlbF9scl9jb250ZXh0X2Rlc2NyaXB0b3IocnEwLT5jdHgsIHJxMC0+ ZW5naW5lKTsKKwlycTAtPmVsc3Bfc3VibWl0dGVkKys7CisKKwkvKiBZb3UgbXVzdCBhbHdheXMg d3JpdGUgYm90aCBkZXNjcmlwdG9ycyBpbiB0aGUgb3JkZXIgYmVsb3cuICovCisJd3JpdGVsKHVw cGVyXzMyX2JpdHMoZGVzY1sxXSksIGVsc3ApOworCXdyaXRlbChsb3dlcl8zMl9iaXRzKGRlc2Nb MV0pLCBlbHNwKTsKKworCXdyaXRlbCh1cHBlcl8zMl9iaXRzKGRlc2NbMF0pLCBlbHNwKTsKKwkv KiBUaGUgY29udGV4dCBpcyBhdXRvbWF0aWNhbGx5IGxvYWRlZCBhZnRlciB0aGUgZm9sbG93aW5n ICovCisJd3JpdGVsKGxvd2VyXzMyX2JpdHMoZGVzY1swXSksIGVsc3ApOworfQorCiBzdGF0aWMg dm9pZCBleGVjbGlzdHNfZWxzcF9zdWJtaXRfY29udGV4dHMoc3RydWN0IGRybV9pOTE1X2dlbV9y ZXF1ZXN0ICpycTAsCiAJCQkJCSAgIHN0cnVjdCBkcm1faTkxNV9nZW1fcmVxdWVzdCAqcnExKQog ewpAQCAtNDAyLDIwICs0MTYsNiBAQCBzdGF0aWMgdm9pZCBleGVjbGlzdHNfZWxzcF9zdWJtaXRf Y29udGV4dHMoc3RydWN0IGRybV9pOTE1X2dlbV9yZXF1ZXN0ICpycTAsCiAJc3Bpbl91bmxvY2tf aXJxKCZkZXZfcHJpdi0+dW5jb3JlLmxvY2spOwogfQogCi1zdGF0aWMgaW5saW5lIHZvaWQgZXhl Y2xpc3RzX2NvbnRleHRfc3RhdHVzX2NoYW5nZSgKLQkJc3RydWN0IGRybV9pOTE1X2dlbV9yZXF1 ZXN0ICpycSwKLQkJdW5zaWduZWQgbG9uZyBzdGF0dXMpCi17Ci0JLyoKLQkgKiBPbmx5IHVzZWQg d2hlbiBHVlQtZyBpcyBlbmFibGVkIG5vdy4gV2hlbiBHVlQtZyBpcyBkaXNhYmxlZCwKLQkgKiBU aGUgY29tcGlsZXIgc2hvdWxkIGVsaW1pbmF0ZSB0aGlzIGZ1bmN0aW9uIGFzIGRlYWQtY29kZS4K LQkgKi8KLQlpZiAoIUlTX0VOQUJMRUQoQ09ORklHX0RSTV9JOTE1X0dWVCkpCi0JCXJldHVybjsK LQotCWF0b21pY19ub3RpZmllcl9jYWxsX2NoYWluKCZycS0+Y3R4LT5zdGF0dXNfbm90aWZpZXIs IHN0YXR1cywgcnEpOwotfQotCiBzdGF0aWMgdm9pZCBleGVjbGlzdHNfdW5xdWV1ZShzdHJ1Y3Qg aW50ZWxfZW5naW5lX2NzICplbmdpbmUpCiB7CiAJc3RydWN0IGRybV9pOTE1X2dlbV9yZXF1ZXN0 ICpyZXEwID0gTlVMTCwgKnJlcTEgPSBOVUxMOwotLSAKMi45LjMKCl9fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCkludGVsLWdmeCBtYWlsaW5nIGxpc3QKSW50 ZWwtZ2Z4QGxpc3RzLmZyZWVkZXNrdG9wLm9yZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9y Zy9tYWlsbWFuL2xpc3RpbmZvL2ludGVsLWdmeAo=