Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1707286imu; Fri, 9 Nov 2018 23:33:15 -0800 (PST) X-Google-Smtp-Source: AJdET5dJU5Oza0dqyo9qOMpo3oDh2IRX1GyjtMvCNNGTkBkCL3AL0gTO8xFMTrMqYtLoBGzUchLG X-Received: by 2002:a63:cb4a:: with SMTP id m10mr9957145pgi.105.1541835195460; Fri, 09 Nov 2018 23:33:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541835195; cv=none; d=google.com; s=arc-20160816; b=jBG/ujatQU2YURNemEiRsbufuzmhmDEWrHY3bSwxRFE7aVmbLsqYYy5Np0H+VgvSgV DWkMhypnEdAK5P1+yW58KIv8nUDyDv+fuvU6jf3J4v+S01Gf6vrlHheQZfCP1HkesKTM 3MZCeEDPvDJmWQ4yxjLXC7vXUYfBa+3JTTSNfxp13FdcqiqteqV8MEOJsHGxGYeZxJS2 oD22lME8IQEXYjGz7ZuARblTVv9FZp7uApONBG6PxMEwu1pB7JEhV7K8qkcyADxwWj02 A7Mv62gSCs15d5QH2hpBQLEx0TJUjYkdqoYLLvkb9QMYzfMmQq1wiBDA6WdQ/L+9S6GS aoww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=fjPWVgfXA2VNnFZcsEwQFthBj/hbHn8dIrVvMnZhsGo=; b=OJNhfixcl74cT5i+4oiomrC3ElOxy7czpRJXBVmdgPF6bJLSRzH5vZTqzj191rfyeU rGVHC3bBgZhGpwZNxpyetA2SAQg38oDKxiRyl1O9WwOpqIdsoBaCZh/Gcaa/28wj5qQO +PoN9G0Dij5I3LuOcBC+Lq0sxGaNTGUzjNRoAKgwaBlgO+8DMj14jo6hOSNmcrd+QCLf kAayPYit6MPujkgHIwtDjAr/l7YyNjjBaWcdhD02XzUq99QgdTfjvQ2UKQS8l/Wi/pPK m+XfGY5ffW+FOvd1wyCDa1CIynJbf943tZxYW04JEoBk4/dQSKKKnywfXk1OvtRRNH+2 EJqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=l+5QGUR4; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a61-v6si11324438pla.430.2018.11.09.23.32.46; Fri, 09 Nov 2018 23:33:15 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=l+5QGUR4; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728951AbeKJRQQ (ORCPT + 99 others); Sat, 10 Nov 2018 12:16:16 -0500 Received: from mail-io1-f67.google.com ([209.85.166.67]:35730 "EHLO mail-io1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728682AbeKJRQQ (ORCPT ); Sat, 10 Nov 2018 12:16:16 -0500 Received: by mail-io1-f67.google.com with SMTP id 79-v6so2927010iou.2 for ; Fri, 09 Nov 2018 23:32:14 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=fjPWVgfXA2VNnFZcsEwQFthBj/hbHn8dIrVvMnZhsGo=; b=l+5QGUR4NyOW8xKcGgZtrjGC8EcErxUcnCN5N0ksCHg7ad4/jrtRXThKa3LCd42l3n 1TB18YAw9fs8+R20zVDPWH9HyMyvyY8RH6x1zRHn/5bMMzQCe0WE0r3aBgqAB9hXrdkQ JVKzbdQz0+F+Hw2JH78NyDick9b4Wf8CnII8k= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=fjPWVgfXA2VNnFZcsEwQFthBj/hbHn8dIrVvMnZhsGo=; b=BJ6iimTu8mBqr7vj739VbLvoGuIHbGcxTG/ztn2jhHO420Ks6n5gsC8bLgNiy7+e5i EBK6asQL7gHdYGJal9DXZibZ2jtPoKPbaL5r3GEsaRUjIW8k9cxQqISeZ4eoXQVezs1h XxAmWK0mrUui+Z65co4NW2JYMizGYETDjvhSDpt95Hjv7hgOhqdnTK8z07f2zjHKt6JS UVtLQBZAiABzSTyPBb2yTbPgjA8PRbjv3KqhZeqyZ/3Mvx+RaFx+bDCZyCQcSVBQNA8p qbwydznC5Njl5dptjanS4jDdu0GTQ3HdfG9BZZQCxqqlcrS2zuUF4JdjaVvjVsKy0fMy N6og== X-Gm-Message-State: AGRZ1gLPycqFHposUFG/pLCizC9a+oQY12WH8SUc8QkAEMPmbpoYQycJ V1nSQVyOQRR1bn6L/CMG/IS4NBQGG2MO+A/vrwmVQQ== X-Received: by 2002:a6b:918b:: with SMTP id t133-v6mr9648726iod.267.1541835133443; Fri, 09 Nov 2018 23:32:13 -0800 (PST) MIME-Version: 1.0 References: <20181026144344.27778-1-jagan@amarulasolutions.com> <20181026144344.27778-18-jagan@amarulasolutions.com> <3c4c8a08-8c1e-1ac6-2b53-81389d69c97b@samsung.com> <25c24350-4acd-68b8-ef5d-75a60094f0b6@samsung.com> In-Reply-To: <25c24350-4acd-68b8-ef5d-75a60094f0b6@samsung.com> From: Jagan Teki Date: Sat, 10 Nov 2018 13:02:01 +0530 Message-ID: Subject: Re: [PATCH v3 17/25] dt-bindings: panel: Add Bananapi S070WV20-CT16 ICN6211 MIPI-DSI to RGB bridge To: a.hajda@samsung.com Cc: Chen-Yu Tsai , Maxime Ripard , Icenowy Zheng , Jernej Skrabec , Vasily Khoruzhick , Rob Herring , Mark Rutland , Catalin Marinas , Will Deacon , David Airlie , dri-devel , Michael Turquette , Stephen Boyd , linux-clk , Michael Trimarchi , linux-arm-kernel , devicetree , linux-kernel , linux-sunxi@googlegroups.com Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Nov 7, 2018 at 2:41 PM Andrzej Hajda wrote: > > On 06.11.2018 19:08, Jagan Teki wrote: > > On Wed, Oct 31, 2018 at 2:45 PM Andrzej Hajda wrote: > >> On 31.10.2018 09:58, Chen-Yu Tsai wrote: > >>> On Wed, Oct 31, 2018 at 4:53 PM Andrzej Hajda wrote: > >>>> On 26.10.2018 16:43, Jagan Teki wrote: > >>>>> Bananapi S070WV20-CT16 ICN6211 is 800x480, 4-lane MIPI-DSI to RGB > >>>>> bridge panel, which is available on same PCB with 24-bit RGB interface. > >>>>> > >>>>> So, this patch adds DSI specific binding details on existing > >>>>> dt-bindings file. > >>>>> > >>>>> Signed-off-by: Jagan Teki > >>>>> --- > >>>>> Changes for v3: > >>>>> - Use existing binding doc and update dsi details > >>>>> Changes for v2: > >>>>> - none > >>>>> > >>>>> .../display/panel/bananapi,s070wv20-ct16.txt | 31 +++++++++++++++++-- > >>>>> 1 file changed, 29 insertions(+), 2 deletions(-) > >>>>> > >>>>> diff --git a/Documentation/devicetree/bindings/display/panel/bananapi,s070wv20-ct16.txt b/Documentation/devicetree/bindings/display/panel/bananapi,s070wv20-ct16.txt > >>>>> index 35bc0c839f49..b7855dc7c66f 100644 > >>>>> --- a/Documentation/devicetree/bindings/display/panel/bananapi,s070wv20-ct16.txt > >>>>> +++ b/Documentation/devicetree/bindings/display/panel/bananapi,s070wv20-ct16.txt > >>>>> @@ -1,12 +1,39 @@ > >>>>> Banana Pi 7" (S070WV20-CT16) TFT LCD Panel > >>>>> > >>>>> +S070WV20-CT16 is 7" 800x480 panel connected through a 24-bit RGB interface. > >>>>> + > >>>>> +Depending on the variant, the PCB attached to the panel module either > >>>>> +supports DSI, or DSI + 24-bit RGB. DSI is converted to 24-bit RGB via > >>>>> +an onboard ICN6211 MIPI DSI - RGB bridge chip, then fed to the panel > >>>>> +itself > >>>> As I understand this is display board, which contains 'pure' RGB panel > >>>> S070WV20-CT16 and optionally ICN6211 DSI->RGB bridge. > >>>> These are separate devices, just connected by vendor to simplify its > >>>> assembly. Why don't you create then bridge driver for ICN6211 and RGB > >>>> panel driver for S070WV20-CT16 - it looks more generic. > >>>> Then you can describe both in dts and voila. > >>>> Creating drivers for every combo of devices (panel + bridge), just > >>>> because some vendor sells them together seems incorrect - we have > >>>> devicetree for it. > >>> Rob suggested this, and also the opposite: using the same > >>> "bananapi,s070wv20-ct16" > >>> compatible string for both types of connections, and have the driver deal with > >>> detecting the bus type. > >>> > >>> The thing about the bridge chip is that there's no available datasheet that > >>> describes all the parts of the init sequence, in fact none at all. I managed > >>> to work out some bits, but the others remain a mystery and must be hard-coded > >>> to match the panel. That would work against having a generic bridge driver. > >> > >> But it is common for many chips - 1st version of the driver is developed > >> on one platform and it supports only one configuration, if next platform > >> with the same cheap appears the driver is augmented if necessary. > > At-least few of the commands from panel initialization code, the > > respective opcode data values are based on panel timings and even > > clock value is different in DSI. I think it look hard to try bridge > > driver for these restrictions, do you have any suggestions? > > > Where do you see an issue? Since panel is RGB it should have no > initialization sequence (beside regulator/gpio power on/off), so the > only thing to do is to figure out which regulators/gpios belongs to > which component - with publicly available specs it should be doable. > > The whole initialization sequence is for the bridge, so you put it into > bridge driver, for starters it can be hardcoded. Yes, I understand we can move regulators/gpio setup separately and though we hardcode the init sequence there is difference in clock for DSI(which I mentioned in previous mail). DSI panel can't work with clock used by RGB panel-simple. > > Then you can: > > 1. Try to find other users of this ICN6211 chip and compare > initialization sequences to guess purpose of registers. > > 2. Try to get specs of the chip (ask vendor, distributor, grep Internet). As we mentioned (even Chen-Yu), we are unable to find the proper spec for this panel, all we taken reference from AW BSP code. > > 3. Do nothing - if there will be other users of the bridge they will do > this work. Don't know how we can go with generic bridge driver irrespective of these particular wrinkles, let me know if you have any suggestions.