[PATCH] drm: bridge: it66121: Added it66121 chip external screen status judgment

李云龙 liyunlonga at uniontech.com
Thu Mar 10 08:37:06 UTC 2022


I tested it on Loongarch and MIPS, and the results were fine。
 
 
------------------ Original ------------------
From:  "Neil Armstrong"<narmstrong at baylibre.com>;
Date:  Tue, Sep 21, 2021 08:28 AM
To:  "Yunlongli"<liyunlonga at uniontech.com>; "Phong LE"<ple at baylibre.com>; "Andrzej Hajda"<a.hajda at samsung.com>; "Robert Foss"<robert.foss at linaro.org>; "David Airlie"<airlied at linux.ie>; "Daniel Vetter"<daniel at ffwll.ch>; 
Cc:  "Laurent.pinchart"<Laurent.pinchart at ideasonboard.com>; "Jonas Karlman"<jonas at kwiboo.se>; "Jernej Skrabec"<jernej.skrabec at gmail.com>; "dri-devel"<dri-devel at lists.freedesktop.org>; "linux-kernel"<linux-kernel at vger.kernel.org>; 
Subject:  Re: [PATCH] drm: bridge: it66121: Added it66121 chip external screen status judgment

 

Hi,

On 21/09/2021 09:54, Yunlongli wrote:
> In the actual tests,  the IT66121 chip sometimes misjudged whether
> it had an external screen, so, reference the it66121_user_guid.pdf
> about Audio/Video data is stable or not A typical initialization
> of HDMI link should be based on interrupt signal and appropriate
> register probing. Recommended flow is detailed in IT66121
> Programming Guide. Simply put, the microcontroller should monitor
> the HPD status first. Upon valid HPD event, move on to check
> RxSENDetect register to see if the receiver chip is ready for
> further handshaking. When RxSENDetect is asserted, start reading EDID
> data through DDC channels and carry on the rest of the handshaking
> subsequently.If the micro-controller makes no use of the interrupt
> signal as well as the above-mentioned status  registers, the link
> establishment might fail. Please do follow the suggested
> initialization flow recommended in IT66121 Programming Guide.
> So, I add the IT66121_SYS_STATUS_SENDECTECT register status detection.

Ok, the RxSENDetect is the "rx-sense" detection bit as described in the same doc:

Receiver detection circuit reports the presence or absence of an active termination at the TMDS Clock Channel (RxSENDetect)

The usage of the rx-sense signal in hpd_detect() is not clear because this would break detection of "Fake" EDID dongles or idle monitors.

The dw-hdmi handles the rx-sense, but only to power-on/off the HDMI TX, but only returns the HPD status to DRM without the RX SENSE state,
so it only saves power and doesn't change anything on DRM HPD detection.

So not sure if we should merge this as-is.

Neil

> 
> Signed-off-by: Yunlongli <liyunlonga at uniontech.com>
> ---
>  drivers/gpu/drm/bridge/ite-it66121.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/bridge/ite-it66121.c b/drivers/gpu/drm/bridge/ite-it66121.c
> index 2f2a09adb4bc..9ed4fa298d11 100644
> --- a/drivers/gpu/drm/bridge/ite-it66121.c
> +++ b/drivers/gpu/drm/bridge/ite-it66121.c
> @@ -523,7 +523,7 @@ static bool it66121_is_hpd_detect(struct it66121_ctx *ctx)
>  	if (regmap_read(ctx->regmap, IT66121_SYS_STATUS_REG, &val))
>  		return false;
>  
> -	return val & IT66121_SYS_STATUS_HPDETECT;
> +	return ((val & IT66121_SYS_STATUS_HPDETECT) && (val & IT66121_SYS_STATUS_SENDECTECT));
>  }
>  
>  static int it66121_bridge_attach(struct drm_bridge *bridge,
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20220310/05456154/attachment-0001.htm>


More information about the dri-devel mailing list