Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp666735pxb; Fri, 14 Jan 2022 13:34:01 -0800 (PST) X-Google-Smtp-Source: ABdhPJzCgRgCwNxTVNZV4O5eY11TSoxmn2AYsO0cmof3gK5o7DJbc58A4lrC/d2jR3s6vq1+TbNt X-Received: by 2002:a17:906:1841:: with SMTP id w1mr8700692eje.306.1642196040783; Fri, 14 Jan 2022 13:34:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642196040; cv=none; d=google.com; s=arc-20160816; b=xJHRR5dO3Ab75L1fq+qe+WX+LkV2osVSIO6VtVbaPsRp2GTUh1imHDGqGoDrKtKRTz v33tU7FTGXNJs9iz9OkDxX0hMI1o/Z5p/8XM9qFD33R1OhorTmzXnQT6GPUpAqZ4/Ugm M1FDjLlELGvT05LxD4hQ/bQ5Jem9Z4Eugb4TwQ/cEt6kgwCA/vP713/FZw59evmYMiOz YlXjIjm1m8t3LP8oWnTb+gpPnqT9rayRnDGrCEsdHFrAHA8j7X2B7JlHu4RrnPgs33Tx TPiOqzPm9eCk4hRedMNiCJh9oeusbg1x99AWCyswJAckQ0AGjQkJo3qYOU32hFt2KnEL Gq4Q== 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=ZpQd5MgDxQh1cJDEk6y932cMOfAplIWP9ns8kVsGTvs=; b=ylSTAz9jegq0AzCg8uZVe+sD+lqBg9fDF2+4mISuSg/sLtM6hlnuVi32nv05kgwckN pmGl/Y941jH99uDeRC00zDmODk5bH9Yk3WDNc5AjHGx2JbebYGAW4YMWHW0SsBD5rEnT X/m57sfSLsJavfN+VKPQVan1jzb1AO2ZGXmlek7nacqI7uib73O/r+dYx1JOCSh8oNgm hk1dqssCfDDp5CPF4q95SsGMkzzrUnAVw1MeU2GpOObWu3PgKMtgV4Nl4AFbQbeBfsFE Zt72bwWa0R2RxPKXuhYZnZe8u+XcAlpB1aVFjhEHN72MUeKe3thoNL0I7iB8Jm7Kx9Ye zFBw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=YsIluXYE; 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 ch11si2105419edb.10.2022.01.14.13.33.36; Fri, 14 Jan 2022 13:34:00 -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=YsIluXYE; 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 S241760AbiANOkz (ORCPT + 99 others); Fri, 14 Jan 2022 09:40:55 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53270 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238664AbiANOky (ORCPT ); Fri, 14 Jan 2022 09:40:54 -0500 Received: from mail-wr1-x429.google.com (mail-wr1-x429.google.com [IPv6:2a00:1450:4864:20::429]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C596CC061574 for ; Fri, 14 Jan 2022 06:40:53 -0800 (PST) Received: by mail-wr1-x429.google.com with SMTP id k30so15946639wrd.9 for ; Fri, 14 Jan 2022 06:40:53 -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=ZpQd5MgDxQh1cJDEk6y932cMOfAplIWP9ns8kVsGTvs=; b=YsIluXYEpVcxQh6OaELyrcbxtZCROmSMFkzH/03hqq0b+mLWiNouFMiMH8ZmNu+bA0 IMTEZuxu28ot8m0NocPDWlvJ7VPTG5p2Y4yD2MDDQUWKxJZYb+O0AfmZedVdRfluXosU GxucULMfeP8o1RnWf07vmYYXtwOYoa7YzOB4ZYg5tgaTJtP7vNn4zSo34brNxnvXdD8X bNGErBH6bGrZgAg/wy5H0yEZQ3XmLJ2K8IOrdedgPsH6wmgi6gAXfr9QuPy1YtKpMKWl 8+loWj4uJSBc6Eshji3KuK9P6ILvzC756b/HbbxVflFO4KuUQqqOk6RItgGmsJxilnN0 ec3w== 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=ZpQd5MgDxQh1cJDEk6y932cMOfAplIWP9ns8kVsGTvs=; b=TJXolL5JALW/MRFoltZL85TMIOHY/sFLQmEftl7FXqkl3dI44ZaJIZ5B2j3fDPWiEh W5O7P+/32Y4CNZpzDjfd39eGu3gpBgR933wEfbg1MI73Qp4aByoyY8prMU0tzZX1R78Z 64bAVqWmKhucE0AoVV7vuoN9iyKX7W+EFJZeQmCrj2ebRZviWJxHg4IJvEWBXW+TOAK+ lbCbDL+FeaQ3sQ1MzwrpIuP3zqBrN70KIWreYdICvGyEVVvlcBDVUD/O2mqqF5ytLDrv e0KI9ZyHw1eCu7kfBMLCTzK9D6PF8ZjfXr6PozPXbziScn72VIKUvqTLQEDqE3fulzMh /YDg== X-Gm-Message-State: AOAM531D7nN27/6LSjAAoPd1pF5LmO8irXQ9m3x11TSniZwKreeymZYt /RZojQl9o+UtarXO70Z9pMcBRA== X-Received: by 2002:a05:6000:1543:: with SMTP id 3mr4515819wry.683.1642171252217; Fri, 14 Jan 2022 06:40:52 -0800 (PST) Received: from ?IPv6:2001:861:44c0:66c0:a3fc:c40b:5afc:88ee? ([2001:861:44c0:66c0:a3fc:c40b:5afc:88ee]) by smtp.gmail.com with ESMTPSA id h10sm6784315wmh.0.2022.01.14.06.40.51 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 14 Jan 2022 06:40:51 -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> From: Neil Armstrong Organization: Baylibre Message-ID: Date: Fri, 14 Jan 2022 15:40:50 +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 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 > >> >> ==><=============================== >> diff --git a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> index 54d8fdad395f..68f79094f648 100644 >> --- a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> +++ b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c >> @@ -2589,45 +2589,44 @@ static u32 >> *dw_hdmi_bridge_atomic_get_output_bus_fmts(struct drm_bridge *bridge, >> } >> >> /* >> - * Order bus formats from 16bit to 8bit and from YUV422 to RGB >> + * Order bus formats from 16bit to 8bit and from RGB to YUV422 >> * if supported. In any case the default RGB888 format is added >> */ >> >> if (max_bpc >= 16 && info->bpc == 16) { >> + output_fmts[i++] = MEDIA_BUS_FMT_RGB161616_1X48; >> + >> if (info->color_formats & DRM_COLOR_FORMAT_YCRCB444) >> output_fmts[i++] = MEDIA_BUS_FMT_YUV16_1X48; >> - >> - output_fmts[i++] = MEDIA_BUS_FMT_RGB161616_1X48; >> } >> >> if (max_bpc >= 12 && info->bpc >= 12) { >> - if (info->color_formats & DRM_COLOR_FORMAT_YCRCB422) >> - output_fmts[i++] = MEDIA_BUS_FMT_UYVY12_1X24; >> + output_fmts[i++] = MEDIA_BUS_FMT_RGB121212_1X36; >> >> if (info->color_formats & DRM_COLOR_FORMAT_YCRCB444) >> output_fmts[i++] = MEDIA_BUS_FMT_YUV12_1X36; >> >> - output_fmts[i++] = MEDIA_BUS_FMT_RGB121212_1X36; >> + if (info->color_formats & DRM_COLOR_FORMAT_YCRCB422) >> + output_fmts[i++] = MEDIA_BUS_FMT_UYVY12_1X24; >> } >> >> if (max_bpc >= 10 && info->bpc >= 10) { >> - if (info->color_formats & DRM_COLOR_FORMAT_YCRCB422) >> - output_fmts[i++] = MEDIA_BUS_FMT_UYVY10_1X20; >> + output_fmts[i++] = MEDIA_BUS_FMT_RGB101010_1X30; >> >> if (info->color_formats & DRM_COLOR_FORMAT_YCRCB444) >> output_fmts[i++] = MEDIA_BUS_FMT_YUV10_1X30; >> >> - output_fmts[i++] = MEDIA_BUS_FMT_RGB101010_1X30; >> + if (info->color_formats & DRM_COLOR_FORMAT_YCRCB422) >> + output_fmts[i++] = MEDIA_BUS_FMT_UYVY10_1X20; >> } >> >> - if (info->color_formats & DRM_COLOR_FORMAT_YCRCB422) >> - output_fmts[i++] = MEDIA_BUS_FMT_UYVY8_1X16; >> + output_fmts[i++] = MEDIA_BUS_FMT_RGB888_1X24; >> >> if (info->color_formats & DRM_COLOR_FORMAT_YCRCB444) >> output_fmts[i++] = MEDIA_BUS_FMT_YUV8_1X24; >> >> - /* Default 8bit RGB fallback */ >> - output_fmts[i++] = MEDIA_BUS_FMT_RGB888_1X24; >> + if (info->color_formats & DRM_COLOR_FORMAT_YCRCB422) >> + output_fmts[i++] = MEDIA_BUS_FMT_UYVY8_1X16; >> >> *num_output_fmts = i; >> >> ==><=============================== >> >> Neil >> >>> >>> Regards, >>> Biju >>> >