Received: by 2002:a05:7412:6592:b0:d7:7d3a:4fe2 with SMTP id m18csp1138126rdg; Fri, 11 Aug 2023 10:54:26 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFzQldw2LM6o3bgXJEgLNXglXkHtrzrApRWoVje3m9NRoJxZGMI40d9fBFQd91YAkCGDvag X-Received: by 2002:a17:90a:b112:b0:26b:2ec4:5d78 with SMTP id z18-20020a17090ab11200b0026b2ec45d78mr1807390pjq.0.1691776465885; Fri, 11 Aug 2023 10:54:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691776465; cv=none; d=google.com; s=arc-20160816; b=skivqov6lScD1LFNa49ci04ffS3o51lyvy7IHoq29mH0GoCGvSFS4ImaezINDftUpD VZcKBSaikvtGKyqAchN8SJrq96xTewJt3gRBISbgPLWBAkqLrKokqG3wJXfvk08hVJZO E9AEdPKGthXf310o8iiQAEjAfUPlXZS4k2TKYQX4TCR1JKePP8dr9eRMyr55Dl3y7hRn NnJ1F5331w70HmRqqnu/Bk3gcLHeHHctZe0W2jmoptlplx9twrd4g5NJgb+P1Uo7c7cJ nzfhctTzZnK+fJx09yGoehUaeHzD2vMtuGTlspYiRnYtI+HX2eFLHYLNWIxTdgCVbBJO R24Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=u9awCjaQL9waCthlD3O5soGHjZpDd9+OTYEaBFjDDxU=; fh=RCCKe594xFPZHhttKxAvsFO+Y6hBYHfmXPRHi7qps4s=; b=Kywa2gRoWUvpbP9dIyR8X0xgYzKxtfFS4Xxho+23tAG1//6sZ1OjkiKyIHpWORlvY5 W0X2Zcsr+K0f2HTJgx8xH9+X4Kz7evg4FbU/AVJPnR0NpIrfaLM8pexXKZb1AGMNpPKI n/OEIGdziYfkrjGwjv9mpJB3jcjAigN5BMwiw7taPOaKtTKHFKLTQE6K7ylflM8HoeAl Wqm4enABPAK9tkdAEi/kvHeN9sNPPwXwDCvnQh9VO3cQPyPkgF0cqpB4FwQw/R8z9eJL IeufmJ3fMOVJQPi/Y/iXLMNsubirVBGQ0JEdNZR+JITwJ1ihpgfIG4lVLY20PpPc98em nmUQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=QZ3AH09x; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id t12-20020a17090a3b4c00b0026902b035d8si3732528pjf.18.2023.08.11.10.54.13; Fri, 11 Aug 2023 10:54:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=QZ3AH09x; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236230AbjHKRGM (ORCPT + 99 others); Fri, 11 Aug 2023 13:06:12 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36354 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236234AbjHKRGG (ORCPT ); Fri, 11 Aug 2023 13:06:06 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2369330CD for ; Fri, 11 Aug 2023 10:06:05 -0700 (PDT) Received: from [192.168.88.20] (91-154-35-171.elisa-laajakaista.fi [91.154.35.171]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id AC780FA6; Fri, 11 Aug 2023 19:04:51 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1691773493; bh=aaPoirlmZg6vlC83FhqXIwEasaSW+9wd+nAmaSdq26s=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=QZ3AH09xCtZ+D3q2U5Vuz+ewShCcXC+7lgdaJDLmdVx8d8wczR12ug4vWdtpCP1HE NiQFgcy/ea+zdMYuQ7PwwyxGmWZbOCaC6tX+JszlZP8CScAcXpxYEk/OK8By/FIRi9 9hU/tSG+WOC/3gXB6QRO78xwWArbN7z8J5T/Qah4= Message-ID: Date: Fri, 11 Aug 2023 20:05:58 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH 05/11] drm/bridge: tc358768: Print logical values, not raw register values Content-Language: en-US To: =?UTF-8?Q?P=c3=a9ter_Ujfalusi?= , Andrzej Hajda , Neil Armstrong , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , David Airlie , Daniel Vetter , Francesco Dolcini Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Aradhya Bhatia References: <20230804-tc358768-v1-0-1afd44b7826b@ideasonboard.com> <20230804-tc358768-v1-5-1afd44b7826b@ideasonboard.com> From: Tomi Valkeinen In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_PASS,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/08/2023 19:31, Péter Ujfalusi wrote: > > > On 04/08/2023 13:44, Tomi Valkeinen wrote: >> The driver debug prints DSI related timings as raw register values in >> hex. It is much more useful to see the "logical" value of the timing, >> not the register value. > > I'm a bit confused by the term 'logical' value, I think you meant > decimal, easier to read by humans numbers. Not just decimal. Previously the code printed the register values, which e.g. could contain two values ORed together. So, with "logical" I just meant the "real" value, instead of "register-encoded". >> Change the prints to print the values separately, in case a single >> register contains multiple values, and use %u to have it in a more human >> consumable form. > > But, yes, decimal is better for the dmesg, as I recall I had a tool > which was using hex numbers so it was better to have the prints also in hex. > > Reviewed-by: Peter Ujfalusi > >> >> Signed-off-by: Tomi Valkeinen >> --- >> drivers/gpu/drm/bridge/tc358768.c | 21 ++++++++++++--------- >> 1 file changed, 12 insertions(+), 9 deletions(-) >> >> diff --git a/drivers/gpu/drm/bridge/tc358768.c b/drivers/gpu/drm/bridge/tc358768.c >> index 9b633038af33..0ef51d04bb21 100644 >> --- a/drivers/gpu/drm/bridge/tc358768.c >> +++ b/drivers/gpu/drm/bridge/tc358768.c >> @@ -739,57 +739,59 @@ static void tc358768_bridge_pre_enable(struct drm_bridge *bridge) >> >> /* LP11 > 100us for D-PHY Rx Init */ >> val = tc358768_ns_to_cnt(100 * 1000, dsibclk_nsk) - 1; >> - dev_dbg(priv->dev, "LINEINITCNT: 0x%x\n", val); >> + dev_dbg(priv->dev, "LINEINITCNT: %u\n", val); >> tc358768_write(priv, TC358768_LINEINITCNT, val); >> >> /* LPTimeCnt > 50ns */ >> val = tc358768_ns_to_cnt(50, dsibclk_nsk) - 1; >> lptxcnt = val; >> - dev_dbg(priv->dev, "LPTXTIMECNT: 0x%x\n", val); >> + dev_dbg(priv->dev, "LPTXTIMECNT: %u\n", val); >> tc358768_write(priv, TC358768_LPTXTIMECNT, val); >> >> /* 38ns < TCLK_PREPARE < 95ns */ >> val = tc358768_ns_to_cnt(65, dsibclk_nsk) - 1; >> + dev_dbg(priv->dev, "TCLK_PREPARECNT %u\n", val); >> /* TCLK_PREPARE + TCLK_ZERO > 300ns */ >> val2 = tc358768_ns_to_cnt(300 - tc358768_to_ns(2 * ui_nsk), >> dsibclk_nsk) - 2; >> + dev_dbg(priv->dev, "TCLK_ZEROCNT %u\n", val2); >> val |= val2 << 8; >> - dev_dbg(priv->dev, "TCLK_HEADERCNT: 0x%x\n", val); >> tc358768_write(priv, TC358768_TCLK_HEADERCNT, val); >> >> /* TCLK_TRAIL > 60ns AND TEOT <= 105 ns + 12*UI */ >> raw_val = tc358768_ns_to_cnt(60 + tc358768_to_ns(2 * ui_nsk), dsibclk_nsk) - 5; >> val = clamp(raw_val, 0, 127); >> - dev_dbg(priv->dev, "TCLK_TRAILCNT: 0x%x\n", val); >> + dev_dbg(priv->dev, "TCLK_TRAILCNT: %u\n", val); >> tc358768_write(priv, TC358768_TCLK_TRAILCNT, val); >> >> /* 40ns + 4*UI < THS_PREPARE < 85ns + 6*UI */ >> val = 50 + tc358768_to_ns(4 * ui_nsk); >> val = tc358768_ns_to_cnt(val, dsibclk_nsk) - 1; >> + dev_dbg(priv->dev, "THS_PREPARECNT %u\n", val); >> /* THS_PREPARE + THS_ZERO > 145ns + 10*UI */ >> raw_val = tc358768_ns_to_cnt(145 - tc358768_to_ns(3 * ui_nsk), dsibclk_nsk) - 10; >> val2 = clamp(raw_val, 0, 127); >> + dev_dbg(priv->dev, "THS_ZEROCNT %u\n", val2); >> val |= val2 << 8; >> - dev_dbg(priv->dev, "THS_HEADERCNT: 0x%x\n", val); >> tc358768_write(priv, TC358768_THS_HEADERCNT, val); >> >> /* TWAKEUP > 1ms in lptxcnt steps */ >> val = tc358768_ns_to_cnt(1020000, dsibclk_nsk); >> val = val / (lptxcnt + 1) - 1; >> - dev_dbg(priv->dev, "TWAKEUP: 0x%x\n", val); >> + dev_dbg(priv->dev, "TWAKEUP: %u\n", val); >> tc358768_write(priv, TC358768_TWAKEUP, val); >> >> /* TCLK_POSTCNT > 60ns + 52*UI */ >> val = tc358768_ns_to_cnt(60 + tc358768_to_ns(52 * ui_nsk), >> dsibclk_nsk) - 3; >> - dev_dbg(priv->dev, "TCLK_POSTCNT: 0x%x\n", val); >> + dev_dbg(priv->dev, "TCLK_POSTCNT: %u\n", val); >> tc358768_write(priv, TC358768_TCLK_POSTCNT, val); >> >> /* max(60ns + 4*UI, 8*UI) < THS_TRAILCNT < 105ns + 12*UI */ >> raw_val = tc358768_ns_to_cnt(60 + tc358768_to_ns(18 * ui_nsk), >> dsibclk_nsk) - 4; >> val = clamp(raw_val, 0, 15); >> - dev_dbg(priv->dev, "THS_TRAILCNT: 0x%x\n", val); >> + dev_dbg(priv->dev, "THS_TRAILCNT: %u\n", val); >> tc358768_write(priv, TC358768_THS_TRAILCNT, val); >> >> val = BIT(0); >> @@ -803,10 +805,11 @@ static void tc358768_bridge_pre_enable(struct drm_bridge *bridge) >> /* TXTAGOCNT[26:16] RXTASURECNT[10:0] */ >> val = tc358768_to_ns((lptxcnt + 1) * dsibclk_nsk * 4); >> val = tc358768_ns_to_cnt(val, dsibclk_nsk) / 4 - 1; >> + dev_dbg(priv->dev, "TXTAGOCNT: %u\n", val); >> val2 = tc358768_ns_to_cnt(tc358768_to_ns((lptxcnt + 1) * dsibclk_nsk), >> dsibclk_nsk) - 2; >> + dev_dbg(priv->dev, "RXTASURECNT: %u\n", val2); >> val = val << 16 | val2; >> - dev_dbg(priv->dev, "BTACNTRL1: 0x%x\n", val); >> tc358768_write(priv, TC358768_BTACNTRL1, val); >> >> /* START[0] */ >> >