From mboxrd@z Thu Jan 1 00:00:00 1970 From: =?UTF-8?q?Micha=C5=82=20Winiarski?= Subject: [PATCH 1/3] drm/i915/gtt: Split gen8_ppgtt_clear_pte_range Date: Tue, 4 Oct 2016 15:54:25 +0200 Message-ID: <1475589267-12440-1-git-send-email-michal.winiarski@intel.com> 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 ESMTPS id 768376E682 for ; Tue, 4 Oct 2016 13:54:59 +0000 (UTC) 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 List-Id: intel-gfx@lists.freedesktop.org TGV0J3MgdXNlIG1vcmUgdG9wLWRvd24gYXBwcm9hY2gsIHdoZXJlIGVhY2ggZ2VuOF9wcGd0dF9j bGVhcl8qIGZ1bmN0aW9uCmlzIHJlc3BvbnNpYmxlIGZvciBjbGVhcmluZyB0aGUgc3RydWN0IHBh c3NlZCBhcyBhbiBhcmd1bWVudCBhbmQgY2FsbGluZwpyZWxldmFudCBjbGVhcl9yYW5nZSBmdW5j dGlvbnMgb24gbG93ZXItbGV2ZWwgdGFibGVzLgpEb2luZyB0aGlzIHJhdGhlciB0aGFuIG9wZXJh dGluZyBvbiBQVEUgcmFuZ2VzIG1ha2VzIHRoZSBpbXBsZW1lbnRhdGlvbgpvZiBzaHJpbmtpbmcg cGFnZSB0YWJsZXMgcXVpdGUgc2ltcGxlLgoKQ2M6IENocmlzIFdpbHNvbiA8Y2hyaXNAY2hyaXMt d2lsc29uLmNvLnVrPgpDYzogSm9vbmFzIExhaHRpbmVuIDxqb29uYXMubGFodGluZW5AbGludXgu aW50ZWwuY29tPgpDYzogTWljaGVsIFRoaWVycnkgPG1pY2hlbC50aGllcnJ5QGludGVsLmNvbT4K Q2M6IE1pa2EgS3VvcHBhbGEgPG1pa2Eua3VvcHBhbGFAaW50ZWwuY29tPgpTaWduZWQtb2ZmLWJ5 OiBNaWNoYcWCIFdpbmlhcnNraSA8bWljaGFsLndpbmlhcnNraUBpbnRlbC5jb20+Ci0tLQogZHJp dmVycy9ncHUvZHJtL2k5MTUvaTkxNV9nZW1fZ3R0LmMgfCAxMTUgKysrKysrKysrKysrKysrKysr KysrLS0tLS0tLS0tLS0tLS0tCiAxIGZpbGUgY2hhbmdlZCwgNjYgaW5zZXJ0aW9ucygrKSwgNDkg ZGVsZXRpb25zKC0pCgpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9nZW1f Z3R0LmMgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1X2dlbV9ndHQuYwppbmRleCAwYmI0MjMy Li42MDg2MTIyIDEwMDY0NAotLS0gYS9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1X2dlbV9ndHQu YworKysgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1X2dlbV9ndHQuYwpAQCAtNzA2LDU5ICs3 MDYsODQgQEAgc3RhdGljIGludCBnZW44XzQ4Yl9tbV9zd2l0Y2goc3RydWN0IGk5MTVfaHdfcHBn dHQgKnBwZ3R0LAogCXJldHVybiBnZW44X3dyaXRlX3BkcChyZXEsIDAsIHB4X2RtYSgmcHBndHQt PnBtbDQpKTsKIH0KIAotc3RhdGljIHZvaWQgZ2VuOF9wcGd0dF9jbGVhcl9wdGVfcmFuZ2Uoc3Ry dWN0IGk5MTVfYWRkcmVzc19zcGFjZSAqdm0sCi0JCQkJICAgICAgIHN0cnVjdCBpOTE1X3BhZ2Vf ZGlyZWN0b3J5X3BvaW50ZXIgKnBkcCwKLQkJCQkgICAgICAgdWludDY0X3Qgc3RhcnQsCi0JCQkJ ICAgICAgIHVpbnQ2NF90IGxlbmd0aCwKLQkJCQkgICAgICAgZ2VuOF9wdGVfdCBzY3JhdGNoX3B0 ZSkKK3N0YXRpYyB2b2lkIGdlbjhfcHBndHRfY2xlYXJfcHQoc3RydWN0IGk5MTVfYWRkcmVzc19z cGFjZSAqdm0sCisJCQkJc3RydWN0IGk5MTVfcGFnZV90YWJsZSAqcHQsCisJCQkJdWludDY0X3Qg c3RhcnQsCisJCQkJdWludDY0X3QgbGVuZ3RoLAorCQkJCWJvb2wgdXNlX3NjcmF0Y2gpCiB7CiAJ c3RydWN0IGk5MTVfaHdfcHBndHQgKnBwZ3R0ID0gaTkxNV92bV90b19wcGd0dCh2bSk7CisKKwl1 bnNpZ25lZCBpbnQgcHRlX3N0YXJ0ID0gZ2VuOF9wdGVfaW5kZXgoc3RhcnQpOworCXVuc2lnbmVk IGludCBudW1fZW50cmllcyA9IG1pbihnZW44X3B0ZV9jb3VudChzdGFydCwgbGVuZ3RoKSwKKwkJ CQkgICAgICAgR0VOOF9QVEVTKTsKKwl1aW50NjRfdCBwdGU7CisKIAlnZW44X3B0ZV90ICpwdF92 YWRkcjsKLQl1bnNpZ25lZCBwZHBlID0gZ2VuOF9wZHBlX2luZGV4KHN0YXJ0KTsKLQl1bnNpZ25l ZCBwZGUgPSBnZW44X3BkZV9pbmRleChzdGFydCk7Ci0JdW5zaWduZWQgcHRlID0gZ2VuOF9wdGVf aW5kZXgoc3RhcnQpOwotCXVuc2lnbmVkIG51bV9lbnRyaWVzID0gbGVuZ3RoID4+IFBBR0VfU0hJ RlQ7Ci0JdW5zaWduZWQgbGFzdF9wdGUsIGk7CisJZ2VuOF9wdGVfdCBzY3JhdGNoX3B0ZSA9IGdl bjhfcHRlX2VuY29kZSh2bS0+c2NyYXRjaF9wYWdlLmRhZGRyLAorCQkJCQkJIEk5MTVfQ0FDSEVf TExDLCB1c2Vfc2NyYXRjaCk7CiAKLQlpZiAoV0FSTl9PTighcGRwKSkKKwlpZiAoV0FSTl9PTigh cHhfcGFnZShwdCkpKQogCQlyZXR1cm47CiAKLQl3aGlsZSAobnVtX2VudHJpZXMpIHsKLQkJc3Ry dWN0IGk5MTVfcGFnZV9kaXJlY3RvcnkgKnBkOwotCQlzdHJ1Y3QgaTkxNV9wYWdlX3RhYmxlICpw dDsKKwliaXRtYXBfY2xlYXIocHQtPnVzZWRfcHRlcywgcHRlX3N0YXJ0LCBudW1fZW50cmllcyk7 CiAKLQkJaWYgKFdBUk5fT04oIXBkcC0+cGFnZV9kaXJlY3RvcnlbcGRwZV0pKQotCQkJYnJlYWs7 CisJcHRfdmFkZHIgPSBrbWFwX3B4KHB0KTsKIAotCQlwZCA9IHBkcC0+cGFnZV9kaXJlY3Rvcnlb cGRwZV07CisJZm9yIChwdGUgPSBwdGVfc3RhcnQ7IHB0ZSA8IG51bV9lbnRyaWVzOyBwdGUrKykK KwkJcHRfdmFkZHJbcHRlXSA9IHNjcmF0Y2hfcHRlOwogCisJa3VubWFwX3B4KHBwZ3R0LCBwdF92 YWRkcik7Cit9CisKK3N0YXRpYyB2b2lkIGdlbjhfcHBndHRfY2xlYXJfcGQoc3RydWN0IGk5MTVf YWRkcmVzc19zcGFjZSAqdm0sCisJCQkJc3RydWN0IGk5MTVfcGFnZV9kaXJlY3RvcnkgKnBkLAor CQkJCXVpbnQ2NF90IHN0YXJ0LAorCQkJCXVpbnQ2NF90IGxlbmd0aCwKKwkJCQlib29sIHVzZV9z Y3JhdGNoKQoreworCXN0cnVjdCBpOTE1X3BhZ2VfdGFibGUgKnB0OworCXVpbnQ2NF90IHBkZTsK KworCWdlbjhfZm9yX2VhY2hfcGRlKHB0LCBwZCwgc3RhcnQsIGxlbmd0aCwgcGRlKSB7CiAJCWlm IChXQVJOX09OKCFwZC0+cGFnZV90YWJsZVtwZGVdKSkKIAkJCWJyZWFrOwogCi0JCXB0ID0gcGQt PnBhZ2VfdGFibGVbcGRlXTsKKwkJZ2VuOF9wcGd0dF9jbGVhcl9wdCh2bSwgcHQsIHN0YXJ0LCBs ZW5ndGgsIHVzZV9zY3JhdGNoKTsKKwl9Cit9CiAKLQkJaWYgKFdBUk5fT04oIXB4X3BhZ2UocHQp KSkKLQkJCWJyZWFrOworc3RhdGljIHZvaWQgZ2VuOF9wcGd0dF9jbGVhcl9wZHAoc3RydWN0IGk5 MTVfYWRkcmVzc19zcGFjZSAqdm0sCisJCQkJIHN0cnVjdCBpOTE1X3BhZ2VfZGlyZWN0b3J5X3Bv aW50ZXIgKnBkcCwKKwkJCQkgdWludDY0X3Qgc3RhcnQsCisJCQkJIHVpbnQ2NF90IGxlbmd0aCwK KwkJCQkgYm9vbCB1c2Vfc2NyYXRjaCkKK3sKKwlzdHJ1Y3QgaTkxNV9wYWdlX2RpcmVjdG9yeSAq cGQ7CisJdWludDY0X3QgcGRwZTsKIAotCQlsYXN0X3B0ZSA9IHB0ZSArIG51bV9lbnRyaWVzOwot CQlpZiAobGFzdF9wdGUgPiBHRU44X1BURVMpCi0JCQlsYXN0X3B0ZSA9IEdFTjhfUFRFUzsKKwln ZW44X2Zvcl9lYWNoX3BkcGUocGQsIHBkcCwgc3RhcnQsIGxlbmd0aCwgcGRwZSkgeworCQlpZiAo V0FSTl9PTighcGRwLT5wYWdlX2RpcmVjdG9yeVtwZHBlXSkpCisJCQlicmVhazsKIAotCQlwdF92 YWRkciA9IGttYXBfcHgocHQpOworCQlnZW44X3BwZ3R0X2NsZWFyX3BkKHZtLCBwZCwgc3RhcnQs IGxlbmd0aCwgdXNlX3NjcmF0Y2gpOworCX0KK30KIAotCQlmb3IgKGkgPSBwdGU7IGkgPCBsYXN0 X3B0ZTsgaSsrKSB7Ci0JCQlwdF92YWRkcltpXSA9IHNjcmF0Y2hfcHRlOwotCQkJbnVtX2VudHJp ZXMtLTsKLQkJfQorc3RhdGljIHZvaWQgZ2VuOF9wcGd0dF9jbGVhcl9wbWw0KHN0cnVjdCBpOTE1 X2FkZHJlc3Nfc3BhY2UgKnZtLAorCQkJCSAgc3RydWN0IGk5MTVfcG1sNCAqcG1sNCwKKwkJCQkg IHVpbnQ2NF90IHN0YXJ0LAorCQkJCSAgdWludDY0X3QgbGVuZ3RoLAorCQkJCSAgYm9vbCB1c2Vf c2NyYXRjaCkKK3sKKwlzdHJ1Y3QgaTkxNV9wYWdlX2RpcmVjdG9yeV9wb2ludGVyICpwZHA7CisJ dWludDY0X3QgcG1sNGU7CiAKLQkJa3VubWFwX3B4KHBwZ3R0LCBwdF92YWRkcik7CisJZ2VuOF9m b3JfZWFjaF9wbWw0ZShwZHAsIHBtbDQsIHN0YXJ0LCBsZW5ndGgsIHBtbDRlKSB7CisJCWlmIChX QVJOX09OKCFwbWw0LT5wZHBzW3BtbDRlXSkpCisJCQlicmVhazsKIAotCQlwdGUgPSAwOwotCQlp ZiAoKytwZGUgPT0gSTkxNV9QREVTKSB7Ci0JCQlpZiAoKytwZHBlID09IEk5MTVfUERQRVNfUEVS X1BEUCh2bS0+ZGV2KSkKLQkJCQlicmVhazsKLQkJCXBkZSA9IDA7Ci0JCX0KKwkJZ2VuOF9wcGd0 dF9jbGVhcl9wZHAodm0sIHBkcCwgc3RhcnQsIGxlbmd0aCwgdXNlX3NjcmF0Y2gpOwogCX0KIH0K IApAQCAtNzY4LDIxICs3OTMsMTMgQEAgc3RhdGljIHZvaWQgZ2VuOF9wcGd0dF9jbGVhcl9yYW5n ZShzdHJ1Y3QgaTkxNV9hZGRyZXNzX3NwYWNlICp2bSwKIAkJCQkgICBib29sIHVzZV9zY3JhdGNo KQogewogCXN0cnVjdCBpOTE1X2h3X3BwZ3R0ICpwcGd0dCA9IGk5MTVfdm1fdG9fcHBndHQodm0p OwotCWdlbjhfcHRlX3Qgc2NyYXRjaF9wdGUgPSBnZW44X3B0ZV9lbmNvZGUodm0tPnNjcmF0Y2hf cGFnZS5kYWRkciwKLQkJCQkJCSBJOTE1X0NBQ0hFX0xMQywgdXNlX3NjcmF0Y2gpOwogCi0JaWYg KCFVU0VTX0ZVTExfNDhCSVRfUFBHVFQodm0tPmRldikpIHsKLQkJZ2VuOF9wcGd0dF9jbGVhcl9w dGVfcmFuZ2Uodm0sICZwcGd0dC0+cGRwLCBzdGFydCwgbGVuZ3RoLAotCQkJCQkgICBzY3JhdGNo X3B0ZSk7Ci0JfSBlbHNlIHsKLQkJdWludDY0X3QgcG1sNGU7Ci0JCXN0cnVjdCBpOTE1X3BhZ2Vf ZGlyZWN0b3J5X3BvaW50ZXIgKnBkcDsKLQotCQlnZW44X2Zvcl9lYWNoX3BtbDRlKHBkcCwgJnBw Z3R0LT5wbWw0LCBzdGFydCwgbGVuZ3RoLCBwbWw0ZSkgewotCQkJZ2VuOF9wcGd0dF9jbGVhcl9w dGVfcmFuZ2Uodm0sIHBkcCwgc3RhcnQsIGxlbmd0aCwKLQkJCQkJCSAgIHNjcmF0Y2hfcHRlKTsK LQkJfQotCX0KKwlpZiAoIVVTRVNfRlVMTF80OEJJVF9QUEdUVCh2bS0+ZGV2KSkKKwkJZ2VuOF9w cGd0dF9jbGVhcl9wZHAodm0sICZwcGd0dC0+cGRwLCBzdGFydCwgbGVuZ3RoLAorCQkJCSAgICAg dXNlX3NjcmF0Y2gpOworCWVsc2UKKwkJZ2VuOF9wcGd0dF9jbGVhcl9wbWw0KHZtLCAmcHBndHQt PnBtbDQsIHN0YXJ0LCBsZW5ndGgsCisJCQkJICAgICAgdXNlX3NjcmF0Y2gpOwogfQogCiBzdGF0 aWMgdm9pZAotLSAKMi43LjQKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fCkludGVsLWdmeCBtYWlsaW5nIGxpc3QKSW50ZWwtZ2Z4QGxpc3RzLmZyZWVkZXNr dG9wLm9yZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2lu dGVsLWdmeAo=