Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3356967pxb; Mon, 17 Jan 2022 18:28:48 -0800 (PST) X-Google-Smtp-Source: ABdhPJxVB73BdF4XRB7WjJOcsOuwqFZ6T0tlCk3Lm83iYZ+3z/UPvAGb4nJBystsc6/tw08nIeLR X-Received: by 2002:a17:902:d103:b0:14a:421f:a66 with SMTP id w3-20020a170902d10300b0014a421f0a66mr25447137plw.2.1642472928670; Mon, 17 Jan 2022 18:28:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642472928; cv=none; d=google.com; s=arc-20160816; b=TWtoVOh8eFA9/DUkDNJWoDD6AmgRgDOFeZdPWtfFgaE89kme+Nk0lDOVMkiN2KJeFt xPKGwsC9qp6GsqEkxeq5IGiaO+Ssfr7tWFOg0stscpNH83bezp1zQ9BjB+cP+nbHEjMS T0FFoNUzB8fAQa34zPyKPE9W/TZEZweC29I7Du1teSitD/vBB/80QU/XxPGjFtQxnkvL 3Ha4s50s8STxMM1pzRTf1UJuN6lx+dgwmBjmWNRmFB5Km56vricFOi1iU5OHRgBusmcY 1yx5dk000nmmYJBWu8OaEWZvMkcXI7WYOuEAALR8MN0wttzwc6TY4lyV3o1+kGmUANzp d0bg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:cc:to:subject:dkim-signature; bh=LiIpTlntYSITuyTI+izCWqQctqMJoHIqLwhsNG7Wr5U=; b=F/V4O8KJwq9Zqet8SeYv65Xa76QKf9Qi1Pa5lCGnwtBB+F06fUZbnfe+LRRvDunhV0 Jq5r3jMOuY8l3ztGo3jfiGlUaz3hP08xAwg0Fg/EgJXNlTHc5f0DfA/mijoQNjJVP7vJ qj66QdL78YPYcFfX15uyMpDzq0Oapz6LnM7MD4+bRQiUTTQiXy11fvFTICZQdkQWbbkB eSup9gV3jFd4xMGjve0jgauFepkLH3zW+w+rYwJ3S/+96wX1m6Id4faZ9BmF/52Y6Up9 GADW8AolOGMojvEhDg2WMAAES2s3qkoDjJJlMW9794g9UJ3b/jzBlUo3ss+dAhQvYVdu h7qQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=qE6ah31S; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r74si15564059pfc.17.2022.01.17.18.28.36; Mon, 17 Jan 2022 18:28:48 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=qE6ah31S; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232854AbiAQNwi (ORCPT + 99 others); Mon, 17 Jan 2022 08:52:38 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58060 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232713AbiAQNwh (ORCPT ); Mon, 17 Jan 2022 08:52:37 -0500 Received: from mail-wm1-x32c.google.com (mail-wm1-x32c.google.com [IPv6:2a00:1450:4864:20::32c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 59A6AC061574 for ; Mon, 17 Jan 2022 05:52:37 -0800 (PST) Received: by mail-wm1-x32c.google.com with SMTP id d18-20020a05600c251200b0034974323cfaso24511216wma.4 for ; Mon, 17 Jan 2022 05:52:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20210112.gappssmtp.com; s=20210112; h=subject:to:cc:references:from:organization:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=LiIpTlntYSITuyTI+izCWqQctqMJoHIqLwhsNG7Wr5U=; b=qE6ah31Sf7qAX0aKKpqgEvkfTJoD3IAZ2Et0Cs13BT9V0N1rDZwuhTshWbJsnHGkra RgKUBa3BR+lKePeYV+rYSMJG73zOpsLNoFTImT2ksJvXRx2UX6f18kXXHztwitoMU6uX waLcQOzEmt14knHnbOaeUQARObO4pzfHV2WlpZUUdEQdvJItfctT0DnOAfwPwcwV298V dCX9BfqpnRrNzrGTks16HWNrt7n0lVOa+yMPpflgKSuFu8/w/0jLF/CcSsP2QVaLhftu KKYRkjtuOzykcKJ/sV7MboGAmEhbr5eMuA+o1xpbBQaSYKG0JrJMHwmQG3BbvuscSun1 186g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:subject:to:cc:references:from:organization :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=LiIpTlntYSITuyTI+izCWqQctqMJoHIqLwhsNG7Wr5U=; b=FhEMVeukABOLJVc7/pbETCSn7VVpj1Xw01b6oeq5/exdCgnQ5tlhJgR11KUTnj+VRn GgNFRnHS7tQVmUuYOt6T7eZhJSyANhLfo9pYDAOvf5aJbbcVZUyOBjf0K/Hyie94ZuMY fGfgd9WHcEcFlDQrcWqFeFxhUQW1MohTi4u4NQZLPkcRrONYQZWUvQ1+pV3BtMyEw3Mg 7pvOyEdPc/pW6zkrIQQeifySFoTUlX/DZ4nc397WdgUSpzBDy/3gGtsmDcngucPXUX5k tIEokP1/Es1XZGG3Z6u1+VnRfvK41GgGTZXboLpjn/WbDgPeFqonF11xjq7qODHbzyIN SIwQ== X-Gm-Message-State: AOAM530pQY6LcbY4n2YOllQxW9pqtDfWr6s8pDGe0PXrfGUQ7rEqv66F d/a0mG+CvhsY9kfj+nkgpDuBEQ== X-Received: by 2002:adf:fa08:: with SMTP id m8mr19312390wrr.221.1642427555728; Mon, 17 Jan 2022 05:52:35 -0800 (PST) Received: from ?IPv6:2001:861:44c0:66c0:c004:9fe1:fbda:2d0c? ([2001:861:44c0:66c0:c004:9fe1:fbda:2d0c]) by smtp.gmail.com with ESMTPSA id q206sm14506847wme.8.2022.01.17.05.52.34 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 17 Jan 2022 05:52:35 -0800 (PST) Subject: Re: dw_hdmi is showing wrong colour after commit 7cd70656d1285b79("drm/bridge: display-connector: implement bus fmts callbacks") To: Biju Das , Fabio Estevam Cc: "daniel@ffwll.ch" , "Laurent.pinchart@ideasonboard.com" , "robert.foss@linaro.org" , "jonas@kwiboo.se" , "jernej.skrabec@gmail.com" , "martin.blumenstingl@googlemail.com" , "linux-amlogic@lists.infradead.org" , "linux-arm-kernel@lists.infradead.org" , "dri-devel@lists.freedesktop.org" , "linux-kernel@vger.kernel.org" , "linux-renesas-soc@vger.kernel.org" References: <502f3ec4-fea4-8e14-c7a9-39418fc05d6d@baylibre.com> <19dd6013-8a31-b2ed-29d5-93fc44193ce4@baylibre.com> <538b8da4-1201-5f45-2abf-ecd22c867358@baylibre.com> <80fdc5a0-ddb8-5a0f-eb8c-ef7988ced638@baylibre.com> From: Neil Armstrong Organization: Baylibre Message-ID: Date: Mon, 17 Jan 2022 14:52:34 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.14.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17/01/2022 13:13, Biju Das wrote: > Hi Neil, >> Subject: Re: dw_hdmi is showing wrong colour after commit >> 7cd70656d1285b79("drm/bridge: display-connector: implement bus fmts >> callbacks") >> >> Hi again, >> >> On 14/01/2022 15:40, Neil Armstrong wrote: >>> Hi, >>> >>> On 14/01/2022 15:23, Biju Das wrote: >>>> >>>> >>>>> -----Original Message----- >>>>> From: Neil Armstrong >>>>> Sent: 14 January 2022 13:56 >>>>> To: Biju Das ; Fabio Estevam >>>>> >>>>> Cc: daniel@ffwll.ch; Laurent.pinchart@ideasonboard.com; >>>>> robert.foss@linaro.org; jonas@kwiboo.se; jernej.skrabec@gmail.com; >>>>> martin.blumenstingl@googlemail.com; >>>>> linux-amlogic@lists.infradead.org; >>>>> linux-arm-kernel@lists.infradead.org; >>>>> dri-devel@lists.freedesktop.org; linux-kernel@vger.kernel.org; >>>>> linux-renesas-soc@vger.kernel.org >>>>> Subject: Re: dw_hdmi is showing wrong colour after commit >>>>> 7cd70656d1285b79("drm/bridge: display-connector: implement bus fmts >>>>> callbacks") >>>>> >>>>> Hi, >>>>> >>>>> On 14/01/2022 12:08, Biju Das wrote: >>>>>> Hi Neil, >>>>>> >>>>>>> Subject: Re: dw_hdmi is showing wrong colour after commit >>>>>>> 7cd70656d1285b79("drm/bridge: display-connector: implement bus >>>>>>> fmts >>>>>>> callbacks") >>>>>>> >>>>>>> On 14/01/2022 09:29, Biju Das wrote: >>>>>>>> Hi Neil, >>>>>>>> >>>>>>>> + renesas-soc >>>>>>>> >>>>>>>>> Subject: Re: dw_hdmi is showing wrong colour after commit >>>>>>>>> 7cd70656d1285b79("drm/bridge: display-connector: implement bus >>>>>>>>> fmts >>>>>>>>> callbacks") >>>>>>>>> >>>>>>>>> Hi, >>>>>>>>> >>>>>>>>> On 13/01/2022 21:01, Fabio Estevam wrote: >>>>>>>>>> Hi Biju, >>>>>>>>>> >>>>>>>>>> On Thu, Jan 13, 2022 at 2:45 PM Biju Das >>>>>>>>>> >>>>>>>>> wrote: >>>>>>>>>>> >>>>>>>>>>> Hi All, >>>>>>>>>>> >>>>>>>>>>> RZ/G2{H, M, N} SoC has dw_hdmi IP and it was working >>>>>>>>>>> ok(colour) till the commit >>>>>>>>>>> 7cd70656d1285b79("drm/bridge: display-connector: implement bus >>>>>>>>>>> fmts >>>>>>>>> callbacks"). >>>>>>>>>>> >>>>>>>>>>> After this patch, the screen becomes greenish(may be it is >>>>>>>>>>> setting it >>>>>>>>> into YUV format??). >>>>>>>>>>> >>>>>>>>>>> By checking the code, previously it used to call get_input_fmt >>>>>>>>>>> callback >>>>>>>>> and set colour as RGB24. >>>>>>>>>>> >>>>>>>>>>> After this commit, it calls get_output_fmt_callbck and returns >>>>>>>>>>> 3 outputformats(YUV16, YUV24 and RGB24) And get_input_fmt >>>>>>>>>>> callback, I see >>>>>>>>> the outputformat as YUV16 instead of RGB24. >>>>>>>>>>> >>>>>>>>>>> Not sure, I am the only one seeing this issue with dw_HDMI >> driver. >>>>>>>>> >>>>>>>>> This patch was introduced to maintain the bridge color format >>>>>>>>> negotiation after using DRM_BRIDGE_ATTACH_NO_CONNECTOR, but it >>>>>>>>> seems it behaves incorrectly if the first bridge doesn't >>>>>>>>> implement the negotiation callbacks. >>>>>>>>> >>>>>>>>> Let me check the code to see how to fix that. >>>>>>>> >>>>>>>> Thanks for the information, I am happy to test the patch/fix. >>>>>>>> >>>>>>>> Cheers, >>>>>>>> Biju >>>>>>>> >>>>>>>>> >>>>>>>>>> >>>>>>>>>> I have tested linux-next 20220112 on a imx6q-sabresd board, >>>>>>>>>> which >>>>>>> shows: >>>>>>>>>> >>>>>>>>>> dwhdmi-imx 120000.hdmi: Detected HDMI TX controller v1.30a with >>>>>>>>>> HDCP (DWC HDMI 3D TX PHY) >>>>>>>>>> >>>>>>>>>> The colors are shown correctly here. >>>>>>>>>> >>>>>>>>> >>>>>>>>> The imx doesn't use DRM_BRIDGE_ATTACH_NO_CONNECTOR so the >>>>>>>>> negotiation fails and use the RGB fallback input & output format. >>>>>>>>> >>>>>>>>> Anyway thanks for testing >>>>>>>>> >>>>>>>>> Neil >>>>>>> >>>>>>> Can you test : >>>>>>> >>>>>>> ==><=============================== >>>>>>> diff --git a/drivers/gpu/drm/drm_bridge.c >>>>>>> b/drivers/gpu/drm/drm_bridge.c index c96847fc0ebc..7019acd37716 >>>>>>> 100644 >>>>>>> --- a/drivers/gpu/drm/drm_bridge.c >>>>>>> +++ b/drivers/gpu/drm/drm_bridge.c >>>>>>> @@ -955,7 +955,14 @@ >>>>>>> drm_atomic_bridge_chain_select_bus_fmts(struct >>>>>>> drm_bridge *bridge, >>>>>>> last_bridge_state = >>>>>>> drm_atomic_get_new_bridge_state(crtc_state- >>>>>>>> state, >>>>>>> >>>>>>> last_bridge); >>>>>>> >>>>>>> - if (last_bridge->funcs->atomic_get_output_bus_fmts) { >>>>>>> + /* >>>>>>> + * Only negociate with real values if both end of the >>>>>>> + bridge >>>>> chain >>>>>>> + * support negociation callbacks, otherwise you can end in >>>>>>> + a >>>>>>> situation >>>>>>> + * where the selected output format doesn't match with the >>>>>>> + first >>>>>>> bridge >>>>>>> + * output format. >>>>>>> + */ >>>>>>> + if (bridge->funcs->atomic_get_input_bus_fmts && >>>>>>> + last_bridge->funcs->atomic_get_output_bus_fmts) { >>>>>>> const struct drm_bridge_funcs *funcs = >>>>>>> last_bridge->funcs; >>>>>>> >>>>>>> /* >>>>>>> @@ -980,7 +987,12 @@ >>>>>>> drm_atomic_bridge_chain_select_bus_fmts(struct >>>>>>> drm_bridge *bridge, >>>>>>> if (!out_bus_fmts) >>>>>>> return -ENOMEM; >>>>>>> >>>>>>> - if (conn->display_info.num_bus_formats && >>>>>>> + /* >>>>>>> + * If first bridge doesn't support negociation, >>>>>>> + use >>>>>>> MEDIA_BUS_FMT_FIXED >>>>>>> + * as a safe value for the whole bridge chain >>>>>>> + */ >>>>>>> + if (bridge->funcs->atomic_get_input_bus_fmts && >>>>>>> + conn->display_info.num_bus_formats && >>>>>>> conn->display_info.bus_formats) >>>>>>> out_bus_fmts[0] = conn- >>>>>>>> display_info.bus_formats[0]; >>>>>>> else >>>>>>> ==><=============================== >>>>>>> >>>>>>> This should exclude your situation where the first bridge doesn't >>>>>>> support negociation. >>>>>> >>>>>> I have tested this fix with Linux next-20220114. Still I see colour >>>>> issue. >>>>>> >>>>>> It is still negotiating and it is calling get_output_fmt_callbck >>>>>> >>>>>> [ 3.460155] ########dw_hdmi_bridge_atomic_get_output_bus_fmts >>>>> MEDIA_BUS_FMT_UYVY8_1X16=0######### >>>>>> [ 3.460180] ########dw_hdmi_bridge_atomic_get_output_bus_fmts >>>>> MEDIA_BUS_FMT_YUV8_1X24=1######### >>>>>> [ 3.460202] ########dw_hdmi_bridge_atomic_get_output_bus_fmts >>>>> MEDIA_BUS_FMT_RGB888_1X24=2######### >>>>>> >>>>>> And In get_input_fmt callback, I See the outputformat as YUV16 >>>>>> instead >>>>> of RGB24. >>>>>> >>>>>> [ 3.460319] ########dw_hdmi_bridge_atomic_get_input_bus_fmts >>>>> MEDIA_BUS_FMT_UYVY8_1X16######### >>>>>> [ 3.473644] ########hdmi_video_sample >>>>> MEDIA_BUS_FMT_UYVY8_1X16######### >>>>> >>>>> OK, looking at rcar-du, the dw-hdmi bridge is directly connected to >>>>> the encoder. >>>> >>>> Yep. >>>> >>>>> >>>>> Let me figure that out, no sure I can find a clean solution except >>>>> putting back RGB24 before YUV. >>>>> >>>>> Anyway please test that: >>>> >>>> It works now after reordering. >>>> >>>> [ 3.493302] ########dw_hdmi_bridge_atomic_get_output_bus_fmts >> MEDIA_BUS_FMT_RGB888_1X24=0######### >>>> [ 3.493326] ########dw_hdmi_bridge_atomic_get_output_bus_fmts >> MEDIA_BUS_FMT_YUV8_1X24=1######### >>>> [ 3.493348] ########dw_hdmi_bridge_atomic_get_output_bus_fmts >> MEDIA_BUS_FMT_UYVY8_1X16=2######### >>>> >>>> [ 3.493463] ########dw_hdmi_bridge_atomic_get_input_bus_fmts >> MEDIA_BUS_FMT_RGB888_1X24######### >>>> [ 3.506797] ########hdmi_video_sample >> MEDIA_BUS_FMT_RGB888_1X24######### >>>> >>>> Is it acceptable solution to the users of dw_hdmi driver? May be it is >> worth to post a patch. >>>> at least it is fixing the colour issue?? >>> >>> Yes, it gets back to default behavior before negociation, nevertheless >>> we need to think how to handle your use-case correctly at some point. >>> >>> I'll post this as a patch ASAP so it gets applied before landing in >> linus master. >>> >>> Neil >>> >>>> >>>> Regards, >>>> Biju >>>> >>>>> >> [...] >> >> I'm not happy with this version since it's merely a hack which makes it >> work. >> >> Can you test the following change instead, it's correctly handles your >> situation in a generic manner. >> >> ========================><============================= >> diff --git a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> index 54d8fdad395f..9f2e1cac0ae2 100644 >> --- a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> +++ b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> @@ -2551,8 +2551,9 @@ static u32 >> *dw_hdmi_bridge_atomic_get_output_bus_fmts(struct drm_bridge *bridge, >> if (!output_fmts) >> return NULL; >> >> - /* If dw-hdmi is the only bridge, avoid negociating with ourselves >> */ >> - if (list_is_singular(&bridge->encoder->bridge_chain)) { >> + /* If dw-hdmi is the first or only bridge, avoid negociating with >> ourselves */ >> + if (list_is_singular(&bridge->encoder->bridge_chain) || >> + list_is_first(&bridge->chain_node, >> + &bridge->encoder->bridge_chain)) { >> *num_output_fmts = 1; >> output_fmts[0] = MEDIA_BUS_FMT_FIXED; >> >> @@ -2673,6 +2674,10 @@ static u32 >> *dw_hdmi_bridge_atomic_get_input_bus_fmts(struct drm_bridge *bridge, >> if (!input_fmts) >> return NULL; >> >> + /* If dw-hdmi is the first bridge fall-back to safe output format >> */ >> + if (list_is_first(&bridge->chain_node, &bridge->encoder- >>> bridge_chain)) >> + output_fmt = MEDIA_BUS_FMT_FIXED; >> + >> switch (output_fmt) { >> /* If MEDIA_BUS_FMT_FIXED is tested, return default bus format */ >> case MEDIA_BUS_FMT_FIXED: >> ========================><============================= > > This patch alone fixes the issue. I have tested with Linux-next. > Do we need below code, as it is already taken care in output_bus_fmt callback. You're right in your case the first part is enough. > >> + if (list_is_first(&bridge->chain_node, &bridge->encoder- >>> bridge_chain)) >> + output_fmt = MEDIA_BUS_FMT_FIXED; > > Cheers, > Biju > Thanks for testing, Neil