From mboxrd@z Thu Jan 1 00:00:00 1970 From: Sam Ravnborg Subject: Re: [PATCH 2/3] DRM: ingenic: Add support for Sharp panels Date: Sun, 30 Jun 2019 10:20:47 +0200 Message-ID: <20190630082047.GD5081@ravnborg.org> References: <20190627182114.27299-1-paul@crapouillou.net> <20190627182114.27299-2-paul@crapouillou.net> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from asavdk3.altibox.net (asavdk3.altibox.net [109.247.116.14]) by gabe.freedesktop.org (Postfix) with ESMTPS id 0026E89B78 for ; Sun, 30 Jun 2019 08:20:50 +0000 (UTC) Content-Disposition: inline In-Reply-To: <20190627182114.27299-2-paul@crapouillou.net> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: Paul Cercueil Cc: David Airlie , dri-devel@lists.freedesktop.org, od@zcrc.me, linux-kernel@vger.kernel.org List-Id: dri-devel@lists.freedesktop.org T24gVGh1LCBKdW4gMjcsIDIwMTkgYXQgMDg6MjE6MTNQTSArMDIwMCwgUGF1bCBDZXJjdWVpbCB3 cm90ZToKPiBBZGQgc3VwcG9ydCBmb3IgdGhlIExDRCBwYW5lbHMgdGhhdCBtdXN0IGJlIGRyaXZl biB3aXRoIHRoZQo+IFNoYXJwLXNwZWNpZmljIHNpZ25hbHMgU1BMLCBDTFMsIFJFViwgUFMuCj4g Cj4gQW4gZXhhbXBsZSBvZiBzdWNoIHBhbmVsIGlzIHRoZSBMUzAyMEIxREQwMUQgc3VwcG9ydGVk IGJ5IHRoZQo+IHBhbmVsLXNpbXBsZSBEUk0gcGFuZWwgZHJpdmVyLgo+IAo+IFNpZ25lZC1vZmYt Ynk6IFBhdWwgQ2VyY3VlaWwgPHBhdWxAY3JhcG91aWxsb3UubmV0PgpSZXZpZXdlZC1ieTogU2Ft IFJhdm5ib3JnIDxzYW1AcmF2bmJvcmcub3JnPgoKPiAtLS0KPiAgZHJpdmVycy9ncHUvZHJtL2lu Z2VuaWMvaW5nZW5pYy1kcm0uYyB8IDY0ICsrKysrKysrKysrKysrKysrLS0tLS0tLS0tLQo+ICAx IGZpbGUgY2hhbmdlZCwgNDEgaW5zZXJ0aW9ucygrKSwgMjMgZGVsZXRpb25zKC0pCj4gCj4gZGlm ZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9pbmdlbmljL2luZ2VuaWMtZHJtLmMgYi9kcml2ZXJz L2dwdS9kcm0vaW5nZW5pYy9pbmdlbmljLWRybS5jCj4gaW5kZXggMDJjNDc4OGVmMWM3Li5kYTk2 NmYzZGMxZjcgMTAwNjQ0Cj4gLS0tIGEvZHJpdmVycy9ncHUvZHJtL2luZ2VuaWMvaW5nZW5pYy1k cm0uYwo+ICsrKyBiL2RyaXZlcnMvZ3B1L2RybS9pbmdlbmljL2luZ2VuaWMtZHJtLmMKPiBAQCAt MTY2LDYgKzE2Niw4IEBAIHN0cnVjdCBpbmdlbmljX2RybSB7Cj4gIAo+ICAJc3RydWN0IGluZ2Vu aWNfZG1hX2h3ZGVzYyAqZG1hX2h3ZGVzYzsKPiAgCWRtYV9hZGRyX3QgZG1hX2h3ZGVzY19waHlz Owo+ICsKPiArCWJvb2wgcGFuZWxfaXNfc2hhcnA7Cj4gIH07Cj4gIAo+ICBzdGF0aWMgY29uc3Qg dTMyIGluZ2VuaWNfZHJtX3ByaW1hcnlfZm9ybWF0c1tdID0gewo+IEBAIC0yODMsNiArMjg1LDEz IEBAIHN0YXRpYyB2b2lkIGluZ2VuaWNfZHJtX2NydGNfdXBkYXRlX3RpbWluZ3Moc3RydWN0IGlu Z2VuaWNfZHJtICpwcml2LAo+ICAJcmVnbWFwX3dyaXRlKHByaXYtPm1hcCwgSlpfUkVHX0xDRF9E QVYsCj4gIAkJICAgICB2ZHMgPDwgSlpfTENEX0RBVl9WRFNfT0ZGU0VUIHwKPiAgCQkgICAgIHZk ZSA8PCBKWl9MQ0RfREFWX1ZERV9PRkZTRVQpOwo+ICsKPiArCWlmIChwcml2LT5wYW5lbF9pc19z aGFycCkgewo+ICsJCXJlZ21hcF93cml0ZShwcml2LT5tYXAsIEpaX1JFR19MQ0RfUFMsIGhkZSA8 PCAxNiB8IChoZGUgKyAxKSk7Cj4gKwkJcmVnbWFwX3dyaXRlKHByaXYtPm1hcCwgSlpfUkVHX0xD RF9DTFMsIGhkZSA8PCAxNiB8IChoZGUgKyAxKSk7Cj4gKwkJcmVnbWFwX3dyaXRlKHByaXYtPm1h cCwgSlpfUkVHX0xDRF9TUEwsIGhwZSA8PCAxNiB8IChocGUgKyAxKSk7Cj4gKwkJcmVnbWFwX3dy aXRlKHByaXYtPm1hcCwgSlpfUkVHX0xDRF9SRVYsIG1vZGUtPmh0b3RhbCA8PCAxNik7Cj4gKwl9 Cj4gIH0KPiAgCj4gIHN0YXRpYyB2b2lkIGluZ2VuaWNfZHJtX2NydGNfdXBkYXRlX2N0cmwoc3Ry dWN0IGluZ2VuaWNfZHJtICpwcml2LAo+IEBAIC0zNzgsMTEgKzM4NywxOCBAQCBzdGF0aWMgdm9p ZCBpbmdlbmljX2RybV9lbmNvZGVyX2F0b21pY19tb2RlX3NldChzdHJ1Y3QgZHJtX2VuY29kZXIg KmVuY29kZXIsCj4gIHsKPiAgCXN0cnVjdCBpbmdlbmljX2RybSAqcHJpdiA9IGRybV9lbmNvZGVy X2dldF9wcml2KGVuY29kZXIpOwo+ICAJc3RydWN0IGRybV9kaXNwbGF5X21vZGUgKm1vZGUgPSAm Y3J0Y19zdGF0ZS0+YWRqdXN0ZWRfbW9kZTsKPiAtCXN0cnVjdCBkcm1fZGlzcGxheV9pbmZvICpp bmZvID0gJmNvbm5fc3RhdGUtPmNvbm5lY3Rvci0+ZGlzcGxheV9pbmZvOwo+IC0JdW5zaWduZWQg aW50IGNmZyA9IEpaX0xDRF9DRkdfUFNfRElTQUJMRQo+IC0JCQkgfCBKWl9MQ0RfQ0ZHX0NMU19E SVNBQkxFCj4gLQkJCSB8IEpaX0xDRF9DRkdfU1BMX0RJU0FCTEUKPiAtCQkJIHwgSlpfTENEX0NG R19SRVZfRElTQUJMRTsKPiArCXN0cnVjdCBkcm1fY29ubmVjdG9yICpjb25uID0gY29ubl9zdGF0 ZS0+Y29ubmVjdG9yOwo+ICsJc3RydWN0IGRybV9kaXNwbGF5X2luZm8gKmluZm8gPSAmY29ubi0+ ZGlzcGxheV9pbmZvOwo+ICsJdW5zaWduZWQgaW50IGNmZzsKPiArCj4gKwlwcml2LT5wYW5lbF9p c19zaGFycCA9IGluZm8tPmJ1c19mbGFncyAmIERSTV9CVVNfRkxBR19TSEFSUF9TSUdOQUxTOwo+ ICsKPiArCWlmIChwcml2LT5wYW5lbF9pc19zaGFycCkgewo+ICsJCWNmZyA9IEpaX0xDRF9DRkdf TU9ERV9TUEVDSUFMX1RGVF8xIHwgSlpfTENEX0NGR19SRVZfUE9MQVJJVFk7Cj4gKwl9IGVsc2Ug ewo+ICsJCWNmZyA9IEpaX0xDRF9DRkdfUFNfRElTQUJMRSB8IEpaX0xDRF9DRkdfQ0xTX0RJU0FC TEUKPiArCQkgICAgfCBKWl9MQ0RfQ0ZHX1NQTF9ESVNBQkxFIHwgSlpfTENEX0NGR19SRVZfRElT QUJMRTsKPiArCX0KPiAgCj4gIAlpZiAobW9kZS0+ZmxhZ3MgJiBEUk1fTU9ERV9GTEFHX05IU1lO QykKPiAgCQljZmcgfD0gSlpfTENEX0NGR19IU1lOQ19BQ1RJVkVfTE9XOwo+IEBAIC0zOTMsMjQg KzQwOSwyNiBAQCBzdGF0aWMgdm9pZCBpbmdlbmljX2RybV9lbmNvZGVyX2F0b21pY19tb2RlX3Nl dChzdHJ1Y3QgZHJtX2VuY29kZXIgKmVuY29kZXIsCj4gIAlpZiAoaW5mby0+YnVzX2ZsYWdzICYg RFJNX0JVU19GTEFHX1BJWERBVEFfTkVHRURHRSkKPiAgCQljZmcgfD0gSlpfTENEX0NGR19QQ0xL X0ZBTExJTkdfRURHRTsKPiAgCj4gLQlpZiAoY29ubl9zdGF0ZS0+Y29ubmVjdG9yLT5jb25uZWN0 b3JfdHlwZSA9PSBEUk1fTU9ERV9DT05ORUNUT1JfVFYpIHsKPiAtCQlpZiAobW9kZS0+ZmxhZ3Mg JiBEUk1fTU9ERV9GTEFHX0lOVEVSTEFDRSkKPiAtCQkJY2ZnIHw9IEpaX0xDRF9DRkdfTU9ERV9U Vl9PVVRfSTsKPiAtCQllbHNlCj4gLQkJCWNmZyB8PSBKWl9MQ0RfQ0ZHX01PREVfVFZfT1VUX1A7 Cj4gLQl9IGVsc2Ugewo+IC0JCXN3aXRjaCAoKmluZm8tPmJ1c19mb3JtYXRzKSB7Cj4gLQkJY2Fz ZSBNRURJQV9CVVNfRk1UX1JHQjU2NV8xWDE2Ogo+IC0JCQljZmcgfD0gSlpfTENEX0NGR19NT0RF X0dFTkVSSUNfMTZCSVQ7Cj4gLQkJCWJyZWFrOwo+IC0JCWNhc2UgTUVESUFfQlVTX0ZNVF9SR0I2 NjZfMVgxODoKPiAtCQkJY2ZnIHw9IEpaX0xDRF9DRkdfTU9ERV9HRU5FUklDXzE4QklUOwo+IC0J CQlicmVhazsKPiAtCQljYXNlIE1FRElBX0JVU19GTVRfUkdCODg4XzFYMjQ6Cj4gLQkJCWNmZyB8 PSBKWl9MQ0RfQ0ZHX01PREVfR0VORVJJQ18yNEJJVDsKPiAtCQkJYnJlYWs7Cj4gLQkJZGVmYXVs dDoKPiAtCQkJYnJlYWs7Cj4gKwlpZiAoIXByaXYtPnBhbmVsX2lzX3NoYXJwKSB7Cj4gKwkJaWYg KGNvbm4tPmNvbm5lY3Rvcl90eXBlID09IERSTV9NT0RFX0NPTk5FQ1RPUl9UVikgewo+ICsJCQlp ZiAobW9kZS0+ZmxhZ3MgJiBEUk1fTU9ERV9GTEFHX0lOVEVSTEFDRSkKPiArCQkJCWNmZyB8PSBK Wl9MQ0RfQ0ZHX01PREVfVFZfT1VUX0k7Cj4gKwkJCWVsc2UKPiArCQkJCWNmZyB8PSBKWl9MQ0Rf Q0ZHX01PREVfVFZfT1VUX1A7Cj4gKwkJfSBlbHNlIHsKPiArCQkJc3dpdGNoICgqaW5mby0+YnVz X2Zvcm1hdHMpIHsKPiArCQkJY2FzZSBNRURJQV9CVVNfRk1UX1JHQjU2NV8xWDE2Ogo+ICsJCQkJ Y2ZnIHw9IEpaX0xDRF9DRkdfTU9ERV9HRU5FUklDXzE2QklUOwo+ICsJCQkJYnJlYWs7Cj4gKwkJ CWNhc2UgTUVESUFfQlVTX0ZNVF9SR0I2NjZfMVgxODoKPiArCQkJCWNmZyB8PSBKWl9MQ0RfQ0ZH X01PREVfR0VORVJJQ18xOEJJVDsKPiArCQkJCWJyZWFrOwo+ICsJCQljYXNlIE1FRElBX0JVU19G TVRfUkdCODg4XzFYMjQ6Cj4gKwkJCQljZmcgfD0gSlpfTENEX0NGR19NT0RFX0dFTkVSSUNfMjRC SVQ7Cj4gKwkJCQlicmVhazsKPiArCQkJZGVmYXVsdDoKPiArCQkJCWJyZWFrOwo+ICsJCQl9Cj4g IAkJfQo+ICAJfQo+ICAKPiAtLSAKPiAyLjIxLjAuNTkzLmc1MTFlYzM0NWUxOAo+IAo+IF9fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCj4gZHJpLWRldmVsIG1h aWxpbmcgbGlzdAo+IGRyaS1kZXZlbEBsaXN0cy5mcmVlZGVza3RvcC5vcmcKPiBodHRwczovL2xp c3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2RyaS1kZXZlbApfX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwpkcmktZGV2ZWwgbWFpbGluZyBs aXN0CmRyaS1kZXZlbEBsaXN0cy5mcmVlZGVza3RvcC5vcmcKaHR0cHM6Ly9saXN0cy5mcmVlZGVz a3RvcC5vcmcvbWFpbG1hbi9saXN0aW5mby9kcmktZGV2ZWw= From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.5 required=3.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS, USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 6A1CDC5B57E for ; Sun, 30 Jun 2019 08:22:31 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 48B1B2086D for ; Sun, 30 Jun 2019 08:22:31 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726646AbfF3IUw (ORCPT ); Sun, 30 Jun 2019 04:20:52 -0400 Received: from asavdk3.altibox.net ([109.247.116.14]:38729 "EHLO asavdk3.altibox.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726482AbfF3IUw (ORCPT ); Sun, 30 Jun 2019 04:20:52 -0400 Received: from ravnborg.org (unknown [158.248.194.18]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by asavdk3.altibox.net (Postfix) with ESMTPS id 28FEB20067; Sun, 30 Jun 2019 10:20:49 +0200 (CEST) Date: Sun, 30 Jun 2019 10:20:47 +0200 From: Sam Ravnborg To: Paul Cercueil Cc: David Airlie , Daniel Vetter , od@zcrc.me, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org Subject: Re: [PATCH 2/3] DRM: ingenic: Add support for Sharp panels Message-ID: <20190630082047.GD5081@ravnborg.org> References: <20190627182114.27299-1-paul@crapouillou.net> <20190627182114.27299-2-paul@crapouillou.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190627182114.27299-2-paul@crapouillou.net> User-Agent: Mutt/1.10.1 (2018-07-13) X-CMAE-Score: 0 X-CMAE-Analysis: v=2.3 cv=dqr19Wo4 c=1 sm=1 tr=0 a=UWs3HLbX/2nnQ3s7vZ42gw==:117 a=UWs3HLbX/2nnQ3s7vZ42gw==:17 a=jpOVt7BSZ2e4Z31A5e1TngXxSK0=:19 a=kj9zAlcOel0A:10 a=ER_8r6IbAAAA:8 a=7gkXJVJtAAAA:8 a=e5mUnYsNAAAA:8 a=dZ1WxxcaQ2ST3bnaBBcA:9 a=CjuIK1q_8ugA:10 a=9LHmKk7ezEChjTCyhBa9:22 a=E9Po1WZjFZOl8hwRPBS3:22 a=Vxmtnl_E_bksehYqCbjh:22 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 27, 2019 at 08:21:13PM +0200, Paul Cercueil wrote: > Add support for the LCD panels that must be driven with the > Sharp-specific signals SPL, CLS, REV, PS. > > An example of such panel is the LS020B1DD01D supported by the > panel-simple DRM panel driver. > > Signed-off-by: Paul Cercueil Reviewed-by: Sam Ravnborg > --- > drivers/gpu/drm/ingenic/ingenic-drm.c | 64 +++++++++++++++++---------- > 1 file changed, 41 insertions(+), 23 deletions(-) > > diff --git a/drivers/gpu/drm/ingenic/ingenic-drm.c b/drivers/gpu/drm/ingenic/ingenic-drm.c > index 02c4788ef1c7..da966f3dc1f7 100644 > --- a/drivers/gpu/drm/ingenic/ingenic-drm.c > +++ b/drivers/gpu/drm/ingenic/ingenic-drm.c > @@ -166,6 +166,8 @@ struct ingenic_drm { > > struct ingenic_dma_hwdesc *dma_hwdesc; > dma_addr_t dma_hwdesc_phys; > + > + bool panel_is_sharp; > }; > > static const u32 ingenic_drm_primary_formats[] = { > @@ -283,6 +285,13 @@ static void ingenic_drm_crtc_update_timings(struct ingenic_drm *priv, > regmap_write(priv->map, JZ_REG_LCD_DAV, > vds << JZ_LCD_DAV_VDS_OFFSET | > vde << JZ_LCD_DAV_VDE_OFFSET); > + > + if (priv->panel_is_sharp) { > + regmap_write(priv->map, JZ_REG_LCD_PS, hde << 16 | (hde + 1)); > + regmap_write(priv->map, JZ_REG_LCD_CLS, hde << 16 | (hde + 1)); > + regmap_write(priv->map, JZ_REG_LCD_SPL, hpe << 16 | (hpe + 1)); > + regmap_write(priv->map, JZ_REG_LCD_REV, mode->htotal << 16); > + } > } > > static void ingenic_drm_crtc_update_ctrl(struct ingenic_drm *priv, > @@ -378,11 +387,18 @@ static void ingenic_drm_encoder_atomic_mode_set(struct drm_encoder *encoder, > { > struct ingenic_drm *priv = drm_encoder_get_priv(encoder); > struct drm_display_mode *mode = &crtc_state->adjusted_mode; > - struct drm_display_info *info = &conn_state->connector->display_info; > - unsigned int cfg = JZ_LCD_CFG_PS_DISABLE > - | JZ_LCD_CFG_CLS_DISABLE > - | JZ_LCD_CFG_SPL_DISABLE > - | JZ_LCD_CFG_REV_DISABLE; > + struct drm_connector *conn = conn_state->connector; > + struct drm_display_info *info = &conn->display_info; > + unsigned int cfg; > + > + priv->panel_is_sharp = info->bus_flags & DRM_BUS_FLAG_SHARP_SIGNALS; > + > + if (priv->panel_is_sharp) { > + cfg = JZ_LCD_CFG_MODE_SPECIAL_TFT_1 | JZ_LCD_CFG_REV_POLARITY; > + } else { > + cfg = JZ_LCD_CFG_PS_DISABLE | JZ_LCD_CFG_CLS_DISABLE > + | JZ_LCD_CFG_SPL_DISABLE | JZ_LCD_CFG_REV_DISABLE; > + } > > if (mode->flags & DRM_MODE_FLAG_NHSYNC) > cfg |= JZ_LCD_CFG_HSYNC_ACTIVE_LOW; > @@ -393,24 +409,26 @@ static void ingenic_drm_encoder_atomic_mode_set(struct drm_encoder *encoder, > if (info->bus_flags & DRM_BUS_FLAG_PIXDATA_NEGEDGE) > cfg |= JZ_LCD_CFG_PCLK_FALLING_EDGE; > > - if (conn_state->connector->connector_type == DRM_MODE_CONNECTOR_TV) { > - if (mode->flags & DRM_MODE_FLAG_INTERLACE) > - cfg |= JZ_LCD_CFG_MODE_TV_OUT_I; > - else > - cfg |= JZ_LCD_CFG_MODE_TV_OUT_P; > - } else { > - switch (*info->bus_formats) { > - case MEDIA_BUS_FMT_RGB565_1X16: > - cfg |= JZ_LCD_CFG_MODE_GENERIC_16BIT; > - break; > - case MEDIA_BUS_FMT_RGB666_1X18: > - cfg |= JZ_LCD_CFG_MODE_GENERIC_18BIT; > - break; > - case MEDIA_BUS_FMT_RGB888_1X24: > - cfg |= JZ_LCD_CFG_MODE_GENERIC_24BIT; > - break; > - default: > - break; > + if (!priv->panel_is_sharp) { > + if (conn->connector_type == DRM_MODE_CONNECTOR_TV) { > + if (mode->flags & DRM_MODE_FLAG_INTERLACE) > + cfg |= JZ_LCD_CFG_MODE_TV_OUT_I; > + else > + cfg |= JZ_LCD_CFG_MODE_TV_OUT_P; > + } else { > + switch (*info->bus_formats) { > + case MEDIA_BUS_FMT_RGB565_1X16: > + cfg |= JZ_LCD_CFG_MODE_GENERIC_16BIT; > + break; > + case MEDIA_BUS_FMT_RGB666_1X18: > + cfg |= JZ_LCD_CFG_MODE_GENERIC_18BIT; > + break; > + case MEDIA_BUS_FMT_RGB888_1X24: > + cfg |= JZ_LCD_CFG_MODE_GENERIC_24BIT; > + break; > + default: > + break; > + } > } > } > > -- > 2.21.0.593.g511ec345e18 > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel