From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga03.intel.com (mga03.intel.com [134.134.136.65]) by gabe.freedesktop.org (Postfix) with ESMTPS id 1A9D56EBBA for ; Sat, 3 Nov 2018 11:36:19 +0000 (UTC) From: Jyoti Yadav Date: Sat, 3 Nov 2018 07:36:03 -0400 Message-Id: <1541244966-27134-3-git-send-email-jyoti.r.yadav@intel.com> In-Reply-To: <1541244966-27134-1-git-send-email-jyoti.r.yadav@intel.com> References: <1541244966-27134-1-git-send-email-jyoti.r.yadav@intel.com> MIME-Version: 1.0 Subject: [igt-dev] [PATCH i-g-t v3 2/5] [intel-gfx] tests/pm_dc: Added new test to verify Display C States. List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: igt-dev-bounces@lists.freedesktop.org Sender: "igt-dev" To: igt-dev@lists.freedesktop.org Cc: Jyoti Yadav List-ID: Q3VycmVudGx5IHRoaXMgdGVzdCB2YWxpZGF0ZXMgREM1IHVwb24gUFNSIGVudHJ5IGZvciBzdXBw b3J0ZWQgcGxhdGZvcm1zLgpBZGRlZCBuZXcgZmlsZSBmb3IgY29tcGlsYXRpb24gaW5zaWRlIE1h a2VmaWxlIGFuZCBNZXNvbi4KClNpZ25lZC1vZmYtYnk6IEp5b3RpIFlhZGF2IDxqeW90aS5yLnlh ZGF2QGludGVsLmNvbT4KLS0tCiB0ZXN0cy9NYWtlZmlsZS5zb3VyY2VzIHwgICAxICsKIHRlc3Rz L21lc29uLmJ1aWxkICAgICAgfCAgIDEgKwogdGVzdHMvcG1fZGMuYyAgICAgICAgICB8IDIxMiAr KysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysrCiAzIGZpbGVz IGNoYW5nZWQsIDIxNCBpbnNlcnRpb25zKCspCiBjcmVhdGUgbW9kZSAxMDA2NDQgdGVzdHMvcG1f ZGMuYwoKZGlmZiAtLWdpdCBhL3Rlc3RzL01ha2VmaWxlLnNvdXJjZXMgYi90ZXN0cy9NYWtlZmls ZS5zb3VyY2VzCmluZGV4IGM4NDkzM2YuLmQ0OTE0MjAgMTAwNjQ0Ci0tLSBhL3Rlc3RzL01ha2Vm aWxlLnNvdXJjZXMKKysrIGIvdGVzdHMvTWFrZWZpbGUuc291cmNlcwpAQCAtMjE0LDYgKzIxNCw3 IEBAIFRFU1RTX3Byb2dzID0gXAogCXBtX2xwc3AgXAogCXBtX3JjNl9yZXNpZGVuY3kgXAogCXBt X3JwbSBcCisJcG1fZGMgXAogCXBtX3JwcyBcCiAJcG1fc3NldSBcCiAJcHJpbWVfYnVzeSBcCmRp ZmYgLS1naXQgYS90ZXN0cy9tZXNvbi5idWlsZCBiL3Rlc3RzL21lc29uLmJ1aWxkCmluZGV4IDE3 ZGViOTQuLjUwYjA2ODcgMTAwNjQ0Ci0tLSBhL3Rlc3RzL21lc29uLmJ1aWxkCisrKyBiL3Rlc3Rz L21lc29uLmJ1aWxkCkBAIC0xODgsNiArMTg4LDcgQEAgdGVzdF9wcm9ncyA9IFsKIAkncG1fbHBz cCcsCiAJJ3BtX3JjNl9yZXNpZGVuY3knLAogCSdwbV9ycG0nLAorCSdwbV9kYycsCiAJJ3BtX3Jw cycsCiAJJ3BtX3NzZXUnLAogCSdwcmltZV9idXN5JywKZGlmZiAtLWdpdCBhL3Rlc3RzL3BtX2Rj LmMgYi90ZXN0cy9wbV9kYy5jCm5ldyBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDAwMDAwMDAuLjY3 MWMwZjUKLS0tIC9kZXYvbnVsbAorKysgYi90ZXN0cy9wbV9kYy5jCkBAIC0wLDAgKzEsMjEyIEBA CisvKgorICogQ29weXJpZ2h0IMKpIDIwMTggSW50ZWwgQ29ycG9yYXRpb24KKyAqCisgKiBQZXJt aXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBv YnRhaW5pbmcgYQorICogY29weSBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3Vt ZW50YXRpb24gZmlsZXMgKHRoZSAiU29mdHdhcmUiKSwKKyAqIHRvIGRlYWwgaW4gdGhlIFNvZnR3 YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24KKyAq IHRoZSByaWdodHMgdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmli dXRlLCBzdWJsaWNlbnNlLAorICogYW5kL29yIHNlbGwgY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwg YW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlCisgKiBTb2Z0d2FyZSBpcyBmdXJuaXNo ZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOgorICoKKyAq IFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIChp bmNsdWRpbmcgdGhlIG5leHQKKyAqIHBhcmFncmFwaCkgc2hhbGwgYmUgaW5jbHVkZWQgaW4gYWxs IGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUKKyAqIFNvZnR3YXJlLgorICoK KyAqIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCAiQVMgSVMiLCBXSVRIT1VUIFdBUlJBTlRZIE9G IEFOWSBLSU5ELCBFWFBSRVNTIE9SCisgKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1J VEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwKKyAqIEZJVE5FU1MgRk9S IEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuICBJTiBOTyBFVkVOVCBT SEFMTAorICogVEhFIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBB TlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVIKKyAqIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBB Q1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HCisgKiBGUk9NLCBP VVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9U SEVSIERFQUxJTkdTCisgKiBJTiBUSEUgU09GVFdBUkUuCisgKgorICovCisKKyNpbmNsdWRlICJp Z3QuaCIKKyNpbmNsdWRlICJpZ3Rfc3lzZnMuaCIKKyNpbmNsdWRlICJpZ3RfcHNyLmgiCisjaW5j bHVkZSA8ZXJybm8uaD4KKyNpbmNsdWRlIDxzdGRib29sLmg+CisjaW5jbHVkZSA8c3RkaW8uaD4K KyNpbmNsdWRlIDxzdHJpbmcuaD4KKyNpbmNsdWRlICJpbnRlbF9idWZtZ3IuaCIKKyNpbmNsdWRl ICJpbnRlbF9pby5oIgorI2luY2x1ZGUgImxpbWl0cy5oIgorCisKK3R5cGVkZWYgc3RydWN0IHsK KwlpbnQgZHJtX2ZkOworCWludCBkZWJ1Z2ZzX2ZkOworCXVpbnQzMl90IGRldmlkOworCWlndF9k aXNwbGF5X3QgZGlzcGxheTsKKwlzdHJ1Y3QgaWd0X2ZiIGZiX3doaXRlOworCWRybU1vZGVNb2Rl SW5mbyAqbW9kZTsKKwlpZ3Rfb3V0cHV0X3QgKm91dHB1dDsKK30gZGF0YV90OworCisvKiBEQyBT dGF0ZSBGbGFncyAqLworI2RlZmluZSBDSEVDS19EQzUJMQorI2RlZmluZSBDSEVDS19EQzYJMgor CitzdGF0aWMgdm9pZCBzZXR1cF9vdXRwdXQoZGF0YV90ICpkYXRhKQoreworCWlndF9kaXNwbGF5 X3QgKmRpc3BsYXkgPSAmZGF0YS0+ZGlzcGxheTsKKwlpZ3Rfb3V0cHV0X3QgKm91dHB1dDsKKwll bnVtIHBpcGUgcGlwZTsKKworCWZvcl9lYWNoX3BpcGVfd2l0aF92YWxpZF9vdXRwdXQoZGlzcGxh eSwgcGlwZSwgb3V0cHV0KSB7CisJCWRybU1vZGVDb25uZWN0b3JQdHIgYyA9IG91dHB1dC0+Y29u ZmlnLmNvbm5lY3RvcjsKKworCQlpZiAoYy0+Y29ubmVjdG9yX3R5cGUgIT0gRFJNX01PREVfQ09O TkVDVE9SX2VEUCkKKwkJCWNvbnRpbnVlOworCisJCWlndF9vdXRwdXRfc2V0X3BpcGUob3V0cHV0 LCBwaXBlKTsKKwkJZGF0YS0+b3V0cHV0ID0gb3V0cHV0OworCQlkYXRhLT5tb2RlID0gaWd0X291 dHB1dF9nZXRfbW9kZShvdXRwdXQpOworCisJCXJldHVybjsKKwl9Cit9CisKK3N0YXRpYyB2b2lk IGRpc3BsYXlfaW5pdChkYXRhX3QgKmRhdGEpCit7CisJaWd0X2Rpc3BsYXlfaW5pdCgmZGF0YS0+ ZGlzcGxheSwgZGF0YS0+ZHJtX2ZkKTsKKwlzZXR1cF9vdXRwdXQoZGF0YSk7Cit9CisKK3N0YXRp YyB2b2lkIGRpc3BsYXlfZmluaShkYXRhX3QgKmRhdGEpCit7CisJaWd0X2Rpc3BsYXlfZmluaSgm ZGF0YS0+ZGlzcGxheSk7Cit9CisKK3N0YXRpYyBib29sIGVkcF9wc3Jfc2lua19zdXBwb3J0KGRh dGFfdCAqZGF0YSkKK3sKKwljaGFyIGJ1Zls1MTJdOworCisJaWd0X2RlYnVnZnNfc2ltcGxlX3Jl YWQoZGF0YS0+ZGVidWdmc19mZCwgImk5MTVfZWRwX3Bzcl9zdGF0dXMiLAorCQkJIGJ1Ziwgc2l6 ZW9mKGJ1ZikpOworCisJcmV0dXJuIHN0cnN0cihidWYsICJTaW5rX1N1cHBvcnQ6IHllc1xuIik7 Cit9CisKK3N0YXRpYyB2b2lkIGNsZWFudXAoZGF0YV90ICpkYXRhKQoreworCWlndF9wbGFuZV90 ICpwcmltYXJ5OworCisJcHJpbWFyeSA9IGlndF9vdXRwdXRfZ2V0X3BsYW5lX3R5cGUoZGF0YS0+ b3V0cHV0LAorCQkJCQkgICAgRFJNX1BMQU5FX1RZUEVfUFJJTUFSWSk7CisJaWd0X3BsYW5lX3Nl dF9mYihwcmltYXJ5LCBOVUxMKTsKKwlpZ3RfZGlzcGxheV9jb21taXQoJmRhdGEtPmRpc3BsYXkp OworCWlndF9yZW1vdmVfZmIoZGF0YS0+ZHJtX2ZkLCAmZGF0YS0+ZmJfd2hpdGUpOworfQorCitz dGF0aWMgdm9pZCBzZXR1cF9wcmltYXJ5KGRhdGFfdCAqZGF0YSkKK3sKKwlpZ3RfcGxhbmVfdCAq cHJpbWFyeTsKKworCXByaW1hcnkgPSBpZ3Rfb3V0cHV0X2dldF9wbGFuZV90eXBlKGRhdGEtPm91 dHB1dCwKKwkJCQkJICAgIERSTV9QTEFORV9UWVBFX1BSSU1BUlkpOworCWlndF9wbGFuZV9zZXRf ZmIocHJpbWFyeSwgTlVMTCk7CisJaWd0X2NyZWF0ZV9jb2xvcl9mYihkYXRhLT5kcm1fZmQsCisJ CQkgICAgZGF0YS0+bW9kZS0+aGRpc3BsYXksIGRhdGEtPm1vZGUtPnZkaXNwbGF5LAorCQkJICAg IERSTV9GT1JNQVRfWFJHQjg4ODgsCisJCQkgICAgTE9DQUxfSTkxNV9GT1JNQVRfTU9EX1hfVElM RUQsCisJCQkgICAgMS4wLCAxLjAsIDEuMCwKKwkJCSAgICAmZGF0YS0+ZmJfd2hpdGUpOworCWln dF9kaXNwbGF5X2NvbW1pdCgmZGF0YS0+ZGlzcGxheSk7CisKKwlpZ3RfcGxhbmVfc2V0X2ZiKHBy aW1hcnksICZkYXRhLT5mYl93aGl0ZSk7CisJaWd0X2Rpc3BsYXlfY29tbWl0KCZkYXRhLT5kaXNw bGF5KTsKK30KKworc3RhdGljIHVpbnQzMl90IGdldF9kY19jb3VudGVyKGNoYXIgKmRjX2RhdGEp Cit7CisJY2hhciAqZTsKKwlsb25nIHJldDsKKwljaGFyICpzID0gc3RyY2hyKGRjX2RhdGEsICc6 Jyk7CisKKwlhc3NlcnQocyk7CisJcysrOworCXJldCA9IHN0cnRvbChzLCAmZSwgMTApOworCWFz c2VydCgoKHJldCAhPSBMT05HX01JTiAmJiByZXQgIT0gTE9OR19NQVgpIHx8IGVycm5vICE9IEVS QU5HRSkgJiYKKwkgICAgICAgZSA+IHMgJiYgKmUgPT0gJ1xuJyAmJiByZXQgPj0gMCk7CisJcmV0 dXJuIHJldDsKK30KKworc3RhdGljIHVpbnQzMl90IHJlYWRfZGNfY291bnRlcih1aW50MzJfdCBk cm1fZmQsIGludCBkY19mbGFnKQoreworCWNoYXIgYnVmWzQwOTZdOworCWNoYXIgKnN0cjsKKwor CWlndF9kZWJ1Z2ZzX3JlYWQoZHJtX2ZkLCAiaTkxNV9kbWNfaW5mbyIsIGJ1Zik7CisJaWYgKGRj X2ZsYWcgJiBDSEVDS19EQzUpCisJCXN0ciA9IHN0cnN0cihidWYsICJEQzMgLT4gREM1IGNvdW50 Iik7CisJZWxzZSBpZiAoZGNfZmxhZyAmIENIRUNLX0RDNikKKwkJc3RyID0gc3Ryc3RyKGJ1Ziwg IkRDNSAtPiBEQzYgY291bnQiKTsKKwlpZ3Rfc2tpcF9vbl9mKHN0ciA9PSBOVUxMLCAiREMlZCBj b3VudGVyIGlzIG5vdCBhdmFpbGJsZVxuIiwKKwkJICAgICAgZGNfZmxhZyAmIENIRUNLX0RDNSA/ IDUgOiA2KTsKKwlyZXR1cm4gZ2V0X2RjX2NvdW50ZXIoc3RyKTsKK30KKworYm9vbCBkY19zdGF0 ZV93YWl0X2VudHJ5KGludCBkcm1fZmQsIGludCBkY19mbGFnLCBpbnQgcHJldl9kY19jb3VudCkK K3sKKwlyZXR1cm4gaWd0X3dhaXQocmVhZF9kY19jb3VudGVyKGRybV9mZCwgZGNfZmxhZykgPiBw cmV2X2RjX2NvdW50LCAxMDAwLCAxMDApOworfQorCit2b2lkIGNoZWNrX2RjX2NvdW50ZXIoaW50 IGRybV9mZCwgaW50IGRjX2ZsYWcsIHVpbnQzMl90IHByZXZfZGNfY291bnQpCit7CisJaWd0X2Fz c2VydF9mKGRjX3N0YXRlX3dhaXRfZW50cnkoZHJtX2ZkLCBkY19mbGFnLCBwcmV2X2RjX2NvdW50 KSwKKwkJICAgICAiREMlZCBzdGF0ZSBpcyBub3QgYWNoaWV2ZWRcbiIsCisJCSAgICAgZGNfZmxh ZyAmIENIRUNLX0RDNSA/IDUgOiA2KTsKK30KKworc3RhdGljIHZvaWQgdGVzdF9kY19zdGF0ZV9w c3IoZGF0YV90ICpkYXRhLCBpbnQgZGNfZmxhZykKK3sKKwl1aW50MzJfdCBkY19jb3VudGVyX2Jl Zm9yZV9wc3I7CisKKwlkY19jb3VudGVyX2JlZm9yZV9wc3IgPSByZWFkX2RjX2NvdW50ZXIoZGF0 YS0+ZHJtX2ZkLCBkY19mbGFnKTsKKwlzZXR1cF9vdXRwdXQoZGF0YSk7CisJc2V0dXBfcHJpbWFy eShkYXRhKTsKKwlpZ3RfYXNzZXJ0KHBzcl93YWl0X2VudHJ5KGRhdGEtPmRlYnVnZnNfZmQpKTsK KwljaGVja19kY19jb3VudGVyKGRhdGEtPmRybV9mZCwgZGNfZmxhZywgZGNfY291bnRlcl9iZWZv cmVfcHNyKTsKK30KKworaW50IG1haW4oaW50IGFyZ2MsIGNoYXIgKmFyZ3ZbXSkKK3sKKwlib29s IGhhc19ydW50aW1lX3BtOworCWRhdGFfdCBkYXRhID0ge307CisKKwlpZ3Rfc2tpcF9vbl9zaW11 bGF0aW9uKCk7CisJaWd0X3N1YnRlc3RfaW5pdChhcmdjLCBhcmd2KTsKKwlpZ3RfZml4dHVyZSB7 CisJCWRhdGEuZHJtX2ZkID0gZHJtX29wZW5fZHJpdmVyX21hc3RlcihEUklWRVJfSU5URUwpOwor CQlkYXRhLmRlYnVnZnNfZmQgPSBpZ3RfZGVidWdmc19kaXIoZGF0YS5kcm1fZmQpOworCQlpZ3Rf cmVxdWlyZShkYXRhLmRlYnVnZnNfZmQgIT0gLTEpOworCQlrbXN0ZXN0X3NldF92dF9ncmFwaGlj c19tb2RlKCk7CisJCWRhdGEuZGV2aWQgPSBpbnRlbF9nZXRfZHJtX2RldmlkKGRhdGEuZHJtX2Zk KTsKKwkJaGFzX3J1bnRpbWVfcG0gPSBpZ3Rfc2V0dXBfcnVudGltZV9wbSgpOworCQlpZ3RfaW5m bygiUnVudGltZSBQTSBzdXBwb3J0OiAlZFxuIiwgaGFzX3J1bnRpbWVfcG0pOworCQlpZ3RfcmVx dWlyZShoYXNfcnVudGltZV9wbSk7CisJCWlndF9yZXF1aXJlKGlndF9wbV9kbWNfbG9hZGVkKGRh dGEuZGVidWdmc19mZCkpOworCQlpZ3RfZGlzcGxheV9pbml0KCZkYXRhLT5kaXNwbGF5LCBkYXRh LT5kcm1fZmQpOworCQkvL2Rpc3BsYXlfaW5pdCgmZGF0YSk7CisJfQorCisJaWd0X3N1YnRlc3Qo ImRjNS1wc3IiKSB7CisJCXBzcl9lbmFibGUoZGF0YS5kZWJ1Z2ZzX2ZkKTsKKwkJaWd0X3JlcXVp cmVfZihlZHBfcHNyX3Npbmtfc3VwcG9ydCgmZGF0YSksCisJCQkgICAgICAiU2luayBkb2VzIG5v dCBzdXBwb3J0IFBTUlxuIik7CisJCS8qIENoZWNrIERDNSBjb3VudGVyIGlzIGF2YWlsYWJsZSBm b3IgdGhlIHBsYXRmb3JtLgorCQkgKiBTa2lwIHRoZSB0ZXN0IGlmIGNvdW50ZXIgaXMgbm90IGF2 YWlsYWJsZS4KKwkJICovCisJCXJlYWRfZGNfY291bnRlcihkYXRhLmRybV9mZCwgQ0hFQ0tfREM1 KTsKKwkJdGVzdF9kY19zdGF0ZV9wc3IoJmRhdGEsIENIRUNLX0RDNSk7CisJCWNsZWFudXAoJmRh dGEpOworCX0KKwlpZ3RfZml4dHVyZSB7CisJCWNsb3NlKGRhdGEuZGVidWdmc19mZCk7CisJCWRp c3BsYXlfZmluaSgmZGF0YSk7CisJfQorCisJaWd0X2V4aXQoKTsKK30KLS0gCjEuOS4xCgpfX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwppZ3QtZGV2IG1haWxp bmcgbGlzdAppZ3QtZGV2QGxpc3RzLmZyZWVkZXNrdG9wLm9yZwpodHRwczovL2xpc3RzLmZyZWVk ZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2lndC1kZXYK