From mboxrd@z Thu Jan 1 00:00:00 1970 From: Tvrtko Ursulin Subject: [PATCH 2/7] drm/i915: Record the sseu configuration per-context & engine Date: Tue, 8 Jan 2019 11:22:47 +0000 Message-ID: <20190108112252.29002-3-tvrtko.ursulin@linux.intel.com> References: <20190108112252.29002-1-tvrtko.ursulin@linux.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mga18.intel.com (mga18.intel.com [134.134.136.126]) by gabe.freedesktop.org (Postfix) with ESMTPS id 697F06E99D for ; Tue, 8 Jan 2019 11:22:59 +0000 (UTC) In-Reply-To: <20190108112252.29002-1-tvrtko.ursulin@linux.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 List-Id: intel-gfx@lists.freedesktop.org RnJvbTogTGlvbmVsIExhbmR3ZXJsaW4gPGxpb25lbC5nLmxhbmR3ZXJsaW5AaW50ZWwuY29tPgoK V2Ugd2FudCB0byBleHBvc2UgdGhlIGFiaWxpdHkgdG8gcmVjb25maWd1cmUgdGhlIHNsaWNlcywg c3Vic2xpY2UgYW5kCmV1IHBlciBjb250ZXh0IGFuZCBwZXIgZW5naW5lLiBUbyBmYWNpbGl0YXRl IHRoYXQsIHN0b3JlIHRoZSBjdXJyZW50CmNvbmZpZ3VyYXRpb24gb24gdGhlIGNvbnRleHQgZm9y IGVhY2ggZW5naW5lLCB3aGljaCBpcyBpbml0aWFsbHkgc2V0CnRvIHRoZSBkZXZpY2UgZGVmYXVs dCB1cG9uIGNyZWF0aW9uLgoKdjI6IHJlY29yZCBzc2V1IGNvbmZpZ3VyYXRpb24gcGVyIGNvbnRl eHQgJiBlbmdpbmUgKENocmlzKQoKdjM6IGludHJvZHVjZSB0aGUgaTkxNV9nZW1fY29udGV4dF9z c2V1IHRvIHN0b3JlIHBvd2VyZ2F0aW5nCiAgICBwcm9ncmFtbWluZywgc3NldV9kZXZfaW5mbyBo YXMgZ3Jvd24gcXVpdGUgYSBiaXQgKExpb25lbCkKCnY0OiByZW5hbWUgaTkxNV9nZW1fc3NldSBp bnRvIGludGVsX3NzZXUgKENocmlzKQogICAgdXNlIHRvX2ludGVsX2NvbnRleHQoKSAoQ2hyaXMp Cgp2NTogTW9yZSB0b19pbnRlbF9jb250ZXh0KCkgKFR2cnRrbykKICAgIFN3aXRjaCBpbnRlbF9z c2V1IGZyb20gdW5pb24gdG8gc3RydWN0IChUdnJ0a28pCiAgICBNb3ZlIGNvbnRleHQgZGVmYXVs dCBzc2V1IGluIGV4aXN0aW5nIGxvb3AgKENocmlzKQoKdjY6IHMvaW50ZWxfc3NldV9mcm9tX2Rl dmljZV9zc2V1L2ludGVsX2RldmljZV9kZWZhdWx0X3NzZXUvIChUdnJ0a28pCgpUdnJ0a28gVXJz dWxpbjoKCnY3OgogKiBQYXNzIGludGVsX3NzZXUgYnkgcG9pbnRlciBpbnN0ZWFkIG9mIHZhbHVl IHRvIG1ha2VfcnBjcy4KICogUmViYXNlIGZvciBtYWtlX3JwY3MgY2hhbmdlcy4KCnY4OgogKiBS ZWJhc2UgZm9yIFJQQ1MgZWRpdCBvbiBwaW4uCgp2OToKICogUmViYXNlIGZvciBjb250ZXh0IGlt YWdlIHNldHVwIGNoYW5nZXMuCgp2MTA6CiAqIFJlbmFtZSBkZXZfcHJpdiB0byBpOTE1LiAoQ2hy aXMgV2lsc29uKQoKdjExOgogKiBSZWJhc2UuCgp2MTI6CiAqIFJlYmFzZSBmb3IgSVNfR0VOIGNo YW5nZXMuCgp2MTM6CiAqIFJlYmFzZSBmb3IgUlVOVElNRV9JTkZPLgoKU2lnbmVkLW9mZi1ieTog Q2hyaXMgV2lsc29uIDxjaHJpc0BjaHJpcy13aWxzb24uY28udWs+ClNpZ25lZC1vZmYtYnk6IExp b25lbCBMYW5kd2VybGluIDxsaW9uZWwuZy5sYW5kd2VybGluQGludGVsLmNvbT4KU2lnbmVkLW9m Zi1ieTogVHZydGtvIFVyc3VsaW4gPHR2cnRrby51cnN1bGluQGludGVsLmNvbT4KUmV2aWV3ZWQt Ynk6IENocmlzIFdpbHNvbiA8Y2hyaXNAY2hyaXMtd2lsc29uLmNvLnVrPgotLS0KIGRyaXZlcnMv Z3B1L2RybS9pOTE1L2k5MTVfZHJ2LmggICAgICAgICB8IDE0ICsrKysrKysrKysrCiBkcml2ZXJz L2dwdS9kcm0vaTkxNS9pOTE1X2dlbV9jb250ZXh0LmMgfCAgMiArKwogZHJpdmVycy9ncHUvZHJt L2k5MTUvaTkxNV9nZW1fY29udGV4dC5oIHwgIDQgKysrKwogZHJpdmVycy9ncHUvZHJtL2k5MTUv aTkxNV9yZXF1ZXN0LmggICAgIHwgMTAgKysrKysrKysKIGRyaXZlcnMvZ3B1L2RybS9pOTE1L2lu dGVsX2xyYy5jICAgICAgICB8IDMxICsrKysrKysrKysrKystLS0tLS0tLS0tLS0KIDUgZmlsZXMg Y2hhbmdlZCwgNDYgaW5zZXJ0aW9ucygrKSwgMTUgZGVsZXRpb25zKC0pCgpkaWZmIC0tZ2l0IGEv ZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9kcnYuaCBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5 MTVfZHJ2LmgKaW5kZXggMTdhMDE3NjQ1YzVkLi5kNTc0MzhkODdiYzAgMTAwNjQ0Ci0tLSBhL2Ry aXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfZHJ2LmgKKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUv aTkxNV9kcnYuaApAQCAtMzMwMCw2ICszMzAwLDIwIEBAIG1rd3JpdGVfZGV2aWNlX2luZm8oc3Ry dWN0IGRybV9pOTE1X3ByaXZhdGUgKmRldl9wcml2KQogCXJldHVybiAoc3RydWN0IGludGVsX2Rl dmljZV9pbmZvICopSU5URUxfSU5GTyhkZXZfcHJpdik7CiB9CiAKK3N0YXRpYyBpbmxpbmUgc3Ry dWN0IGludGVsX3NzZXUKK2ludGVsX2RldmljZV9kZWZhdWx0X3NzZXUoc3RydWN0IGRybV9pOTE1 X3ByaXZhdGUgKmk5MTUpCit7CisJY29uc3Qgc3RydWN0IHNzZXVfZGV2X2luZm8gKnNzZXUgPSAm UlVOVElNRV9JTkZPKGk5MTUpLT5zc2V1OworCXN0cnVjdCBpbnRlbF9zc2V1IHZhbHVlID0gewor CQkuc2xpY2VfbWFzayA9IHNzZXUtPnNsaWNlX21hc2ssCisJCS5zdWJzbGljZV9tYXNrID0gc3Nl dS0+c3Vic2xpY2VfbWFza1swXSwKKwkJLm1pbl9ldXNfcGVyX3N1YnNsaWNlID0gc3NldS0+bWF4 X2V1c19wZXJfc3Vic2xpY2UsCisJCS5tYXhfZXVzX3Blcl9zdWJzbGljZSA9IHNzZXUtPm1heF9l dXNfcGVyX3N1YnNsaWNlLAorCX07CisKKwlyZXR1cm4gdmFsdWU7Cit9CisKIC8qIG1vZGVzZXR0 aW5nICovCiBleHRlcm4gdm9pZCBpbnRlbF9tb2Rlc2V0X2luaXRfaHcoc3RydWN0IGRybV9kZXZp Y2UgKmRldik7CiBleHRlcm4gaW50IGludGVsX21vZGVzZXRfaW5pdChzdHJ1Y3QgZHJtX2Rldmlj ZSAqZGV2KTsKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfZ2VtX2NvbnRl eHQuYyBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfZ2VtX2NvbnRleHQuYwppbmRleCA1OTA1 YjZkOGYyOTEuLmE1NjU2NDNlOWEyNiAxMDA2NDQKLS0tIGEvZHJpdmVycy9ncHUvZHJtL2k5MTUv aTkxNV9nZW1fY29udGV4dC5jCisrKyBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2k5MTVfZ2VtX2Nv bnRleHQuYwpAQCAtMzQzLDYgKzM0Myw4IEBAIF9fY3JlYXRlX2h3X2NvbnRleHQoc3RydWN0IGRy bV9pOTE1X3ByaXZhdGUgKmRldl9wcml2LAogCQlzdHJ1Y3QgaW50ZWxfY29udGV4dCAqY2UgPSAm Y3R4LT5fX2VuZ2luZVtuXTsKIAogCQljZS0+Z2VtX2NvbnRleHQgPSBjdHg7CisJCS8qIFVzZSB0 aGUgd2hvbGUgZGV2aWNlIGJ5IGRlZmF1bHQgKi8KKwkJY2UtPnNzZXUgPSBpbnRlbF9kZXZpY2Vf ZGVmYXVsdF9zc2V1KGRldl9wcml2KTsKIAl9CiAKIAlJTklUX1JBRElYX1RSRUUoJmN0eC0+aGFu ZGxlc192bWEsIEdGUF9LRVJORUwpOwpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2k5MTUv aTkxNV9nZW1fY29udGV4dC5oIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9nZW1fY29udGV4 dC5oCmluZGV4IGY2ZDg3MGIxZjczZS4uZWYwNGU0MjJjZjlhIDEwMDY0NAotLS0gYS9kcml2ZXJz L2dwdS9kcm0vaTkxNS9pOTE1X2dlbV9jb250ZXh0LmgKKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5 MTUvaTkxNV9nZW1fY29udGV4dC5oCkBAIC0zMSw2ICszMSw3IEBACiAKICNpbmNsdWRlICJpOTE1 X2dlbS5oIgogI2luY2x1ZGUgImk5MTVfc2NoZWR1bGVyLmgiCisjaW5jbHVkZSAiaW50ZWxfZGV2 aWNlX2luZm8uaCIKIAogc3RydWN0IHBpZDsKIApAQCAtMTcxLDYgKzE3Miw5IEBAIHN0cnVjdCBp OTE1X2dlbV9jb250ZXh0IHsKIAkJaW50IHBpbl9jb3VudDsKIAogCQljb25zdCBzdHJ1Y3QgaW50 ZWxfY29udGV4dF9vcHMgKm9wczsKKworCQkvKiogc3NldTogQ29udHJvbCBldS9zbGljZSBwYXJ0 aXRpb25pbmcgKi8KKwkJc3RydWN0IGludGVsX3NzZXUgc3NldTsKIAl9IF9fZW5naW5lW0k5MTVf TlVNX0VOR0lORVNdOwogCiAJLyoqIHJpbmdfc2l6ZTogc2l6ZSBmb3IgYWxsb2NhdGluZyB0aGUg cGVyLWVuZ2luZSByaW5nIGJ1ZmZlciAqLwpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2k5 MTUvaTkxNV9yZXF1ZXN0LmggYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9pOTE1X3JlcXVlc3QuaApp bmRleCBkMDE0YjA2MDU0NDUuLjkwN2JkOGYxMWFlYiAxMDA2NDQKLS0tIGEvZHJpdmVycy9ncHUv ZHJtL2k5MTUvaTkxNV9yZXF1ZXN0LmgKKysrIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaTkxNV9y ZXF1ZXN0LmgKQEAgLTM4LDYgKzM4LDE2IEBAIHN0cnVjdCBkcm1faTkxNV9nZW1fb2JqZWN0Owog c3RydWN0IGk5MTVfcmVxdWVzdDsKIHN0cnVjdCBpOTE1X3RpbWVsaW5lOwogCisvKgorICogUG93 ZXJnYXRpbmcgY29uZmlndXJhdGlvbiBmb3IgYSBwYXJ0aWN1bGFyIChjb250ZXh0LGVuZ2luZSku CisgKi8KK3N0cnVjdCBpbnRlbF9zc2V1IHsKKwl1OCBzbGljZV9tYXNrOworCXU4IHN1YnNsaWNl X21hc2s7CisJdTggbWluX2V1c19wZXJfc3Vic2xpY2U7CisJdTggbWF4X2V1c19wZXJfc3Vic2xp Y2U7Cit9OworCiBzdHJ1Y3QgaW50ZWxfd2FpdCB7CiAJc3RydWN0IHJiX25vZGUgbm9kZTsKIAlz dHJ1Y3QgdGFza19zdHJ1Y3QgKnRzazsKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1 L2ludGVsX2xyYy5jIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvaW50ZWxfbHJjLmMKaW5kZXggMjI5 ZDYyMGNmMTU3Li42ZGY3OTJiYzUwNjcgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1 L2ludGVsX2xyYy5jCisrKyBiL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2ludGVsX2xyYy5jCkBAIC0x MTcwLDcgKzExNzAsOCBAQCBzdGF0aWMgaW50IF9fY29udGV4dF9waW4oc3RydWN0IGk5MTVfZ2Vt X2NvbnRleHQgKmN0eCwgc3RydWN0IGk5MTVfdm1hICp2bWEpCiAJcmV0dXJuIGk5MTVfdm1hX3Bp bih2bWEsIDAsIDAsIGZsYWdzKTsKIH0KIAotc3RhdGljIHUzMiBtYWtlX3JwY3Moc3RydWN0IGRy bV9pOTE1X3ByaXZhdGUgKmRldl9wcml2KTsKK3N0YXRpYyB1MzIKK21ha2VfcnBjcyhzdHJ1Y3Qg ZHJtX2k5MTVfcHJpdmF0ZSAqaTkxNSwgc3RydWN0IGludGVsX3NzZXUgKmN0eF9zc2V1KTsKIAog c3RhdGljIHZvaWQKIF9fZXhlY2xpc3RzX3VwZGF0ZV9yZWdfc3RhdGUoc3RydWN0IGludGVsX2Vu Z2luZV9jcyAqZW5naW5lLApAQCAtMTE4NSw3ICsxMTg2LDggQEAgX19leGVjbGlzdHNfdXBkYXRl X3JlZ19zdGF0ZShzdHJ1Y3QgaW50ZWxfZW5naW5lX2NzICplbmdpbmUsCiAKIAkvKiBSUENTICov CiAJaWYgKGVuZ2luZS0+Y2xhc3MgPT0gUkVOREVSX0NMQVNTKQotCQlyZWdzW0NUWF9SX1BXUl9D TEtfU1RBVEUgKyAxXSA9IG1ha2VfcnBjcyhlbmdpbmUtPmk5MTUpOworCQlyZWdzW0NUWF9SX1BX Ul9DTEtfU1RBVEUgKyAxXSA9IG1ha2VfcnBjcyhlbmdpbmUtPmk5MTUsCisJCQkJCQkJICAmY2Ut PnNzZXUpOwogfQogCiBzdGF0aWMgc3RydWN0IGludGVsX2NvbnRleHQgKgpAQCAtMjMyNiwxOCAr MjMyOCwxOSBAQCBpbnQgbG9naWNhbF94Y3NfcmluZ19pbml0KHN0cnVjdCBpbnRlbF9lbmdpbmVf Y3MgKmVuZ2luZSkKIH0KIAogc3RhdGljIHUzMgotbWFrZV9ycGNzKHN0cnVjdCBkcm1faTkxNV9w cml2YXRlICpkZXZfcHJpdikKK21ha2VfcnBjcyhzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqaTkx NSwgc3RydWN0IGludGVsX3NzZXUgKmN0eF9zc2V1KQogewotCWJvb2wgc3Vic2xpY2VfcGcgPSBS VU5USU1FX0lORk8oZGV2X3ByaXYpLT5zc2V1Lmhhc19zdWJzbGljZV9wZzsKLQl1OCBzbGljZXMg PSBod2VpZ2h0OChSVU5USU1FX0lORk8oZGV2X3ByaXYpLT5zc2V1LnNsaWNlX21hc2spOwotCXU4 IHN1YnNsaWNlcyA9IGh3ZWlnaHQ4KFJVTlRJTUVfSU5GTyhkZXZfcHJpdiktPnNzZXUuc3Vic2xp Y2VfbWFza1swXSk7CisJY29uc3Qgc3RydWN0IHNzZXVfZGV2X2luZm8gKnNzZXUgPSAmUlVOVElN RV9JTkZPKGk5MTUpLT5zc2V1OworCWJvb2wgc3Vic2xpY2VfcGcgPSBzc2V1LT5oYXNfc3Vic2xp Y2VfcGc7CisJdTggc2xpY2VzID0gaHdlaWdodDgoY3R4X3NzZXUtPnNsaWNlX21hc2spOworCXU4 IHN1YnNsaWNlcyA9IGh3ZWlnaHQ4KGN0eF9zc2V1LT5zdWJzbGljZV9tYXNrKTsKIAl1MzIgcnBj cyA9IDA7CiAKIAkvKgogCSAqIE5vIGV4cGxpY2l0IFJQQ1MgcmVxdWVzdCBpcyBuZWVkZWQgdG8g ZW5zdXJlIGZ1bGwKIAkgKiBzbGljZS9zdWJzbGljZS9FVSBlbmFibGVtZW50IHByaW9yIHRvIEdl bjkuCiAJKi8KLQlpZiAoSU5URUxfR0VOKGRldl9wcml2KSA8IDkpCisJaWYgKElOVEVMX0dFTihp OTE1KSA8IDkpCiAJCXJldHVybiAwOwogCiAJLyoKQEAgLTIzNjUsNyArMjM2OCw3IEBAIG1ha2Vf cnBjcyhzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqZGV2X3ByaXYpCiAJICogc3Vic2xpY2VzIGFy ZSBlbmFibGVkLCBvciBhIGNvdW50IGJldHdlZW4gb25lIGFuZCBmb3VyIG9uIHRoZSBmaXJzdAog CSAqIHNsaWNlLgogCSAqLwotCWlmIChJU19HRU4oZGV2X3ByaXYsIDExKSAmJiBzbGljZXMgPT0g MSAmJiBzdWJzbGljZXMgPj0gNCkgeworCWlmIChJU19HRU4oaTkxNSwgMTEpICYmIHNsaWNlcyA9 PSAxICYmIHN1YnNsaWNlcyA+PSA0KSB7CiAJCUdFTV9CVUdfT04oc3Vic2xpY2VzICYgMSk7CiAK IAkJc3Vic2xpY2VfcGcgPSBmYWxzZTsKQEAgLTIzNzgsMTAgKzIzODEsMTAgQEAgbWFrZV9ycGNz KHN0cnVjdCBkcm1faTkxNV9wcml2YXRlICpkZXZfcHJpdikKIAkgKiBtdXN0IG1ha2UgYW4gZXhw bGljaXQgcmVxdWVzdCB0aHJvdWdoIFJQQ1MgZm9yIGZ1bGwKIAkgKiBlbmFibGVtZW50LgogCSov Ci0JaWYgKFJVTlRJTUVfSU5GTyhkZXZfcHJpdiktPnNzZXUuaGFzX3NsaWNlX3BnKSB7CisJaWYg KHNzZXUtPmhhc19zbGljZV9wZykgewogCQl1MzIgbWFzaywgdmFsID0gc2xpY2VzOwogCi0JCWlm IChJTlRFTF9HRU4oZGV2X3ByaXYpID49IDExKSB7CisJCWlmIChJTlRFTF9HRU4oaTkxNSkgPj0g MTEpIHsKIAkJCW1hc2sgPSBHRU4xMV9SUENTX1NfQ05UX01BU0s7CiAJCQl2YWwgPDw9IEdFTjEx X1JQQ1NfU19DTlRfU0hJRlQ7CiAJCX0gZWxzZSB7CkBAIC0yNDA2LDE4ICsyNDA5LDE2IEBAIG1h a2VfcnBjcyhzdHJ1Y3QgZHJtX2k5MTVfcHJpdmF0ZSAqZGV2X3ByaXYpCiAJCXJwY3MgfD0gR0VO OF9SUENTX0VOQUJMRSB8IEdFTjhfUlBDU19TU19DTlRfRU5BQkxFIHwgdmFsOwogCX0KIAotCWlm IChSVU5USU1FX0lORk8oZGV2X3ByaXYpLT5zc2V1Lmhhc19ldV9wZykgeworCWlmIChzc2V1LT5o YXNfZXVfcGcpIHsKIAkJdTMyIHZhbDsKIAotCQl2YWwgPSBSVU5USU1FX0lORk8oZGV2X3ByaXYp LT5zc2V1LmV1X3Blcl9zdWJzbGljZSA8PAotCQkgICAgICBHRU44X1JQQ1NfRVVfTUlOX1NISUZU OworCQl2YWwgPSBjdHhfc3NldS0+bWluX2V1c19wZXJfc3Vic2xpY2UgPDwgR0VOOF9SUENTX0VV X01JTl9TSElGVDsKIAkJR0VNX0JVR19PTih2YWwgJiB+R0VOOF9SUENTX0VVX01JTl9NQVNLKTsK IAkJdmFsICY9IEdFTjhfUlBDU19FVV9NSU5fTUFTSzsKIAogCQlycGNzIHw9IHZhbDsKIAotCQl2 YWwgPSBSVU5USU1FX0lORk8oZGV2X3ByaXYpLT5zc2V1LmV1X3Blcl9zdWJzbGljZSA8PAotCQkg ICAgICBHRU44X1JQQ1NfRVVfTUFYX1NISUZUOworCQl2YWwgPSBjdHhfc3NldS0+bWF4X2V1c19w ZXJfc3Vic2xpY2UgPDwgR0VOOF9SUENTX0VVX01BWF9TSElGVDsKIAkJR0VNX0JVR19PTih2YWwg JiB+R0VOOF9SUENTX0VVX01BWF9NQVNLKTsKIAkJdmFsICY9IEdFTjhfUlBDU19FVV9NQVhfTUFT SzsKIAotLSAKMi4xOS4xCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fXwpJbnRlbC1nZnggbWFpbGluZyBsaXN0CkludGVsLWdmeEBsaXN0cy5mcmVlZGVza3Rv cC5vcmcKaHR0cHM6Ly9saXN0cy5mcmVlZGVza3RvcC5vcmcvbWFpbG1hbi9saXN0aW5mby9pbnRl bC1nZngK