From mboxrd@z Thu Jan 1 00:00:00 1970 From: Chris Zhong Subject: [PATCH v4 2/6] drm/rockchip/dsi: dw-mipi: support RK3399 mipi dsi Date: Tue, 24 Jan 2017 10:38:02 +0800 Message-ID: <1485225486-669-3-git-send-email-zyw@rock-chips.com> References: <1485225486-669-1-git-send-email-zyw@rock-chips.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: <1485225486-669-1-git-send-email-zyw@rock-chips.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: john@metanate.com, dianders@chromium.org, tfiga@chromium.org, heiko@sntech.de, yzq@rock-chips.com, mark.rutland@arm.com, devicetree@vger.kernel.org, robh+dt@kernel.org, galak@codeaurora.org, pawel.moll@arm.com, seanpaul@chromium.org Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-rockchip@lists.infradead.org, Chris Zhong , linux-arm-kernel@lists.infradead.org List-Id: devicetree@vger.kernel.org VGhlIHZvcGIvdm9wbCBzd2l0Y2ggcmVnaXN0ZXIgb2YgUkszMzk5IG1pcGkgaXMgZGlmZmVyZW50 IGZyb20gUkszMjg4LAp0aGUgZGVmYXVsdCBzZXR0aW5nIGZvciBtaXBpIGRzaSBtb2RlIGlzIGRp ZmZlcmVudCB0b28sIHNvIGFkZCBhCm9mX2RldmljZV9pZCBzdHJ1Y3R1cmUgdG8gZGlzdGluZ3Vp c2ggdGhlbSwgYW5kIG1ha2Ugc3VyZSBzZXQgdGhlCmNvcnJlY3QgbW9kZSBiZWZvcmUgbWlwaSBw aHkgaW5pdC4KClNpZ25lZC1vZmYtYnk6IENocmlzIFpob25nIDx6eXdAcm9jay1jaGlwcy5jb20+ ClNpZ25lZC1vZmYtYnk6IE1hcmsgWWFvIDxtYXJrLnlhb0Byb2NrLWNoaXBzLmNvbT4KCi0tLQoK Q2hhbmdlcyBpbiB2NDoKLSByZW1vdmUgdGhlIHVucmVsYXRlZCBjaGFuZ2UKCkNoYW5nZXMgaW4g djM6Ci0gYmFzZSBvbiBKb2huIEtlZXBpbmcncyBwYXRjaCBzZXJpZXMKCiBkcml2ZXJzL2dwdS9k cm0vcm9ja2NoaXAvZHctbWlwaS1kc2kuYyB8IDY4ICsrKysrKysrKysrKysrKysrKysrKysrKysr KysrLS0tLS0KIDEgZmlsZSBjaGFuZ2VkLCA1OCBpbnNlcnRpb25zKCspLCAxMCBkZWxldGlvbnMo LSkKCmRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vcm9ja2NoaXAvZHctbWlwaS1kc2kuYyBi L2RyaXZlcnMvZ3B1L2RybS9yb2NrY2hpcC9kdy1taXBpLWRzaS5jCmluZGV4IDQ1YWY4OTAuLmI3 YjY3YmUgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9yb2NrY2hpcC9kdy1taXBpLWRzaS5j CisrKyBiL2RyaXZlcnMvZ3B1L2RybS9yb2NrY2hpcC9kdy1taXBpLWRzaS5jCkBAIC0yOSw5ICsy OSwxNyBAQAogCiAjZGVmaW5lIERSSVZFUl9OQU1FICAgICJkdy1taXBpLWRzaSIKIAotI2RlZmlu ZSBHUkZfU09DX0NPTjYgICAgICAgICAgICAgICAgICAgIDB4MDI1YwotI2RlZmluZSBEU0kwX1NF TF9WT1BfTElUICAgICAgICAgICAgICAgICgxIDw8IDYpCi0jZGVmaW5lIERTSTFfU0VMX1ZPUF9M SVQgICAgICAgICAgICAgICAgKDEgPDwgOSkKKyNkZWZpbmUgUkszMjg4X0dSRl9TT0NfQ09ONgkJ MHgwMjVjCisjZGVmaW5lIFJLMzI4OF9EU0kwX1NFTF9WT1BfTElUCQlCSVQoNikKKyNkZWZpbmUg UkszMjg4X0RTSTFfU0VMX1ZPUF9MSVQJCUJJVCg5KQorCisjZGVmaW5lIFJLMzM5OV9HUkZfU09D X0NPTjE5CQkweDYyNTAKKyNkZWZpbmUgUkszMzk5X0RTSTBfU0VMX1ZPUF9MSVQJCUJJVCgwKQor I2RlZmluZSBSSzMzOTlfRFNJMV9TRUxfVk9QX0xJVAkJQklUKDQpCisKKy8qIGRpc2FibGUgdHVy bnJlcXVlc3QsIHR1cm5kaXNhYmxlLCBmb3JjZXR4c3RvcG1vZGUsIGZvcmNlcnhtb2RlICovCisj ZGVmaW5lIFJLMzM5OV9HUkZfU09DX0NPTjIyCQkweDYyNTgKKyNkZWZpbmUgUkszMzk5X0dSRl9E U0lfTU9ERQkJMHhmZmZmMDAwMAogCiAjZGVmaW5lIERTSV9WRVJTSU9OCQkJMHgwMAogI2RlZmlu ZSBEU0lfUFdSX1VQCQkJMHgwNApAQCAtMjY1LDYgKzI3MywxMSBAQCBlbnVtIHsKIH07CiAKIHN0 cnVjdCBkd19taXBpX2RzaV9wbGF0X2RhdGEgeworCXUzMiBkc2kwX2VuX2JpdDsKKwl1MzIgZHNp MV9lbl9iaXQ7CisJdTMyIGdyZl9zd2l0Y2hfcmVnOworCXUzMiBncmZfZHNpMF9tb2RlOworCXUz MiBncmZfZHNpMF9tb2RlX3JlZzsKIAl1bnNpZ25lZCBpbnQgbWF4X2RhdGFfbGFuZXM7CiAJZW51 bSBkcm1fbW9kZV9zdGF0dXMgKCptb2RlX3ZhbGlkKShzdHJ1Y3QgZHJtX2Nvbm5lY3RvciAqY29u bmVjdG9yLAogCQkJCQkgICBzdHJ1Y3QgZHJtX2Rpc3BsYXlfbW9kZSAqbW9kZSk7CkBAIC0yODEs NiArMjk0LDcgQEAgc3RydWN0IGR3X21pcGlfZHNpIHsKIAogCXN0cnVjdCBjbGsgKnBsbHJlZl9j bGs7CiAJc3RydWN0IGNsayAqcGNsazsKKwlzdHJ1Y3QgY2xrICpwaHlfY2ZnX2NsazsKIAogCXVu c2lnbmVkIGludCBsYW5lX21icHM7IC8qIHBlciBsYW5lICovCiAJdTMyIGNoYW5uZWw7CkBAIC00 MjYsNiArNDQwLDE0IEBAIHN0YXRpYyBpbnQgZHdfbWlwaV9kc2lfcGh5X2luaXQoc3RydWN0IGR3 X21pcGlfZHNpICpkc2kpCiAJZHNpX3dyaXRlKGRzaSwgRFNJX1BIWV9UU1RfQ1RSTDAsIFBIWV9U RVNUQ0xSKTsKIAlkc2lfd3JpdGUoZHNpLCBEU0lfUEhZX1RTVF9DVFJMMCwgUEhZX1VOVEVTVENM Uik7CiAKKwlpZiAoIUlTX0VSUihkc2ktPnBoeV9jZmdfY2xrKSkgeworCQlyZXQgPSBjbGtfcHJl cGFyZV9lbmFibGUoZHNpLT5waHlfY2ZnX2Nsayk7CisJCWlmIChyZXQpIHsKKwkJCWRldl9lcnIo ZHNpLT5kZXYsICJGYWlsZWQgdG8gZW5hYmxlIHBoeV9jZmdfY2xrXG4iKTsKKwkJCXJldHVybiBy ZXQ7CisJCX0KKwl9CisKIAlkd19taXBpX2RzaV9waHlfd3JpdGUoZHNpLCAweDEwLCBCWVBBU1Nf VkNPX1JBTkdFIHwKIAkJCQkJIFZDT19SQU5HRV9DT05fU0VMKHZjbykgfAogCQkJCQkgVkNPX0lO X0NBUF9DT05fTE9XIHwKQEAgLTQ3OSwxNyArNTAxLDE5IEBAIHN0YXRpYyBpbnQgZHdfbWlwaV9k c2lfcGh5X2luaXQoc3RydWN0IGR3X21pcGlfZHNpICpkc2kpCiAJCQkJIHZhbCwgdmFsICYgTE9D SywgMTAwMCwgUEhZX1NUQVRVU19USU1FT1VUX1VTKTsKIAlpZiAocmV0IDwgMCkgewogCQlkZXZf ZXJyKGRzaS0+ZGV2LCAiZmFpbGVkIHRvIHdhaXQgZm9yIHBoeSBsb2NrIHN0YXRlXG4iKTsKLQkJ cmV0dXJuIHJldDsKKwkJZ290byBwaHlfaW5pdF9lbmQ7CiAJfQogCiAJcmV0ID0gcmVhZGxfcG9s bF90aW1lb3V0KGRzaS0+YmFzZSArIERTSV9QSFlfU1RBVFVTLAogCQkJCSB2YWwsIHZhbCAmIFNU T1BfU1RBVEVfQ0xLX0xBTkUsIDEwMDAsCiAJCQkJIFBIWV9TVEFUVVNfVElNRU9VVF9VUyk7Ci0J aWYgKHJldCA8IDApIHsKKwlpZiAocmV0IDwgMCkKIAkJZGV2X2Vycihkc2ktPmRldiwKIAkJCSJm YWlsZWQgdG8gd2FpdCBmb3IgcGh5IGNsayBsYW5lIHN0b3Agc3RhdGVcbiIpOwotCQlyZXR1cm4g cmV0OwotCX0KKworcGh5X2luaXRfZW5kOgorCWlmICghSVNfRVJSKGRzaS0+cGh5X2NmZ19jbGsp KQorCQljbGtfZGlzYWJsZV91bnByZXBhcmUoZHNpLT5waHlfY2ZnX2Nsayk7CiAKIAlyZXR1cm4g cmV0OwogfQpAQCAtOTY1LDYgKzk4OSw3IEBAIHN0YXRpYyB2b2lkIGR3X21pcGlfZHNpX2VuY29k ZXJfZGlzYWJsZShzdHJ1Y3QgZHJtX2VuY29kZXIgKmVuY29kZXIpCiBzdGF0aWMgdm9pZCBkd19t aXBpX2RzaV9lbmNvZGVyX2VuYWJsZShzdHJ1Y3QgZHJtX2VuY29kZXIgKmVuY29kZXIpCiB7CiAJ c3RydWN0IGR3X21pcGlfZHNpICpkc2kgPSBlbmNvZGVyX3RvX2RzaShlbmNvZGVyKTsKKwljb25z dCBzdHJ1Y3QgZHdfbWlwaV9kc2lfcGxhdF9kYXRhICpwZGF0YSA9IGRzaS0+cGRhdGE7CiAJaW50 IG11eCA9IGRybV9vZl9lbmNvZGVyX2FjdGl2ZV9lbmRwb2ludF9pZChkc2ktPmRldi0+b2Zfbm9k ZSwgZW5jb2Rlcik7CiAJdTMyIHZhbDsKIApAQCAtOTg1LDYgKzEwMTAsMTAgQEAgc3RhdGljIHZv aWQgZHdfbWlwaV9kc2lfZW5jb2Rlcl9lbmFibGUoc3RydWN0IGRybV9lbmNvZGVyICplbmNvZGVy KQogCWR3X21pcGlfZHNpX2RwaHlfaW50ZXJmYWNlX2NvbmZpZyhkc2kpOwogCWR3X21pcGlfZHNp X2NsZWFyX2Vycihkc2kpOwogCisJaWYgKHBkYXRhLT5ncmZfZHNpMF9tb2RlX3JlZykKKwkJcmVn bWFwX3dyaXRlKGRzaS0+Z3JmX3JlZ21hcCwgcGRhdGEtPmdyZl9kc2kwX21vZGVfcmVnLAorCQkJ ICAgICBwZGF0YS0+Z3JmX2RzaTBfbW9kZSk7CisKIAlkd19taXBpX2RzaV9waHlfaW5pdChkc2kp OwogCWR3X21pcGlfZHNpX3dhaXRfZm9yX3R3b19mcmFtZXMoZHNpKTsKIApAQCAtOTk4LDExICsx MDI3LDExIEBAIHN0YXRpYyB2b2lkIGR3X21pcGlfZHNpX2VuY29kZXJfZW5hYmxlKHN0cnVjdCBk cm1fZW5jb2RlciAqZW5jb2RlcikKIAljbGtfZGlzYWJsZV91bnByZXBhcmUoZHNpLT5wY2xrKTsK IAogCWlmIChtdXgpCi0JCXZhbCA9IERTSTBfU0VMX1ZPUF9MSVQgfCAoRFNJMF9TRUxfVk9QX0xJ VCA8PCAxNik7CisJCXZhbCA9IHBkYXRhLT5kc2kwX2VuX2JpdCB8IChwZGF0YS0+ZHNpMF9lbl9i aXQgPDwgMTYpOwogCWVsc2UKLQkJdmFsID0gRFNJMF9TRUxfVk9QX0xJVCA8PCAxNjsKKwkJdmFs ID0gcGRhdGEtPmRzaTBfZW5fYml0IDw8IDE2OwogCi0JcmVnbWFwX3dyaXRlKGRzaS0+Z3JmX3Jl Z21hcCwgR1JGX1NPQ19DT042LCB2YWwpOworCXJlZ21hcF93cml0ZShkc2ktPmdyZl9yZWdtYXAs IHBkYXRhLT5ncmZfc3dpdGNoX3JlZywgdmFsKTsKIAlkZXZfZGJnKGRzaS0+ZGV2LCAidm9wICVz IG91dHB1dCB0byBkc2kwXG4iLCAobXV4KSA/ICJMSVQiIDogIkJJRyIpOwogfQogCkBAIC0xMTYy LDE0ICsxMTkxLDI5IEBAIHN0YXRpYyBlbnVtIGRybV9tb2RlX3N0YXR1cyByazMyODhfbWlwaV9k c2lfbW9kZV92YWxpZCgKIH0KIAogc3RhdGljIHN0cnVjdCBkd19taXBpX2RzaV9wbGF0X2RhdGEg cmszMjg4X21pcGlfZHNpX2Rydl9kYXRhID0geworCS5kc2kwX2VuX2JpdCA9IFJLMzI4OF9EU0kw X1NFTF9WT1BfTElULAorCS5kc2kxX2VuX2JpdCA9IFJLMzI4OF9EU0kxX1NFTF9WT1BfTElULAor CS5ncmZfc3dpdGNoX3JlZyA9IFJLMzI4OF9HUkZfU09DX0NPTjYsCiAJLm1heF9kYXRhX2xhbmVz ID0gNCwKIAkubW9kZV92YWxpZCA9IHJrMzI4OF9taXBpX2RzaV9tb2RlX3ZhbGlkLAogfTsKIAor c3RhdGljIHN0cnVjdCBkd19taXBpX2RzaV9wbGF0X2RhdGEgcmszMzk5X21pcGlfZHNpX2Rydl9k YXRhID0geworCS5kc2kwX2VuX2JpdCA9IFJLMzM5OV9EU0kwX1NFTF9WT1BfTElULAorCS5kc2kx X2VuX2JpdCA9IFJLMzM5OV9EU0kxX1NFTF9WT1BfTElULAorCS5ncmZfc3dpdGNoX3JlZyA9IFJL MzM5OV9HUkZfU09DX0NPTjE5LAorCS5ncmZfZHNpMF9tb2RlID0gUkszMzk5X0dSRl9EU0lfTU9E RSwKKwkuZ3JmX2RzaTBfbW9kZV9yZWcgPSBSSzMzOTlfR1JGX1NPQ19DT04yMiwKKwkubWF4X2Rh dGFfbGFuZXMgPSA0LAorfTsKKwogc3RhdGljIGNvbnN0IHN0cnVjdCBvZl9kZXZpY2VfaWQgZHdf bWlwaV9kc2lfZHRfaWRzW10gPSB7CiAJewogCSAuY29tcGF0aWJsZSA9ICJyb2NrY2hpcCxyazMy ODgtbWlwaS1kc2kiLAogCSAuZGF0YSA9ICZyazMyODhfbWlwaV9kc2lfZHJ2X2RhdGEsCisJfSwg eworCSAuY29tcGF0aWJsZSA9ICJyb2NrY2hpcCxyazMzOTktbWlwaS1kc2kiLAorCSAuZGF0YSA9 ICZyazMzOTlfbWlwaV9kc2lfZHJ2X2RhdGEsCiAJfSwKIAl7IC8qIHNlbnRpbmVsICovIH0KIH07 CkBAIC0xMjQ5LDYgKzEyOTMsMTAgQEAgc3RhdGljIGludCBkd19taXBpX2RzaV9iaW5kKHN0cnVj dCBkZXZpY2UgKmRldiwgc3RydWN0IGRldmljZSAqbWFzdGVyLAogCQljbGtfZGlzYWJsZV91bnBy ZXBhcmUoZHNpLT5wY2xrKTsKIAl9CiAKKwlkc2ktPnBoeV9jZmdfY2xrID0gZGV2bV9jbGtfZ2V0 KGRldiwgInBoeV9jZmciKTsKKwlpZiAoSVNfRVJSKGRzaS0+cGh5X2NmZ19jbGspKQorCQlkZXZf ZGJnKGRldiwgImhhdmUgbm90IHBoeV9jZmdfY2xrXG4iKTsKKwogCXJldCA9IGNsa19wcmVwYXJl X2VuYWJsZShkc2ktPnBsbHJlZl9jbGspOwogCWlmIChyZXQpIHsKIAkJZGV2X2VycihkZXYsICIl czogRmFpbGVkIHRvIGVuYWJsZSBwbGxyZWZfY2xrXG4iLCBfX2Z1bmNfXyk7Ci0tIAoyLjYuMwoK X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KZHJpLWRldmVs IG1haWxpbmcgbGlzdApkcmktZGV2ZWxAbGlzdHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBzOi8vbGlz dHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vZHJpLWRldmVsCg==